diff options
Diffstat (limited to 'xorg-server/hw/xwin/xlaunch')
| -rw-r--r-- | xorg-server/hw/xwin/xlaunch/config.h | 76 | ||||
| -rw-r--r-- | xorg-server/hw/xwin/xlaunch/main.cc | 20 | ||||
| -rw-r--r-- | xorg-server/hw/xwin/xlaunch/makefile | 32 | ||||
| -rw-r--r-- | xorg-server/hw/xwin/xlaunch/window/makefile | 4 | ||||
| -rw-r--r-- | xorg-server/hw/xwin/xlaunch/window/util.h | 2 | ||||
| -rw-r--r-- | xorg-server/hw/xwin/xlaunch/window/wizard.h | 1 | 
6 files changed, 125 insertions, 10 deletions
| diff --git a/xorg-server/hw/xwin/xlaunch/config.h b/xorg-server/hw/xwin/xlaunch/config.h new file mode 100644 index 000000000..e2774e894 --- /dev/null +++ b/xorg-server/hw/xwin/xlaunch/config.h @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2005 Alexander Gottwald + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE ABOVE LISTED COPYRIGHT HOLDER(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR + * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, + * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + * + * Except as contained in this notice, the name(s) of the above copyright + * holders shall not be used in advertising or otherwise to promote the sale, + * use or other dealings in this Software without prior written authorization. + * + * Authors:	Alexander Gottwald, Colin Harrison + */ +#ifndef __CONFIG_H__ +#define __CONFIG_H__ +#define UNICODE +#define _UNICODE + +#define PROG_NUMBER 10 +#define HOST_NUMBER 10 +#define MAX_MESSAGE 256 +#define MAX_CAPTION 128 + +#include <windows.h> +#include <string> +#include <vector> +struct CConfig +{ +    enum {MultiWindow, Fullscreen, Windowed, Nodecoration} window; +    enum {NoClient, StartProgram, XDMCP} client; +    enum {NoXClient, Local, PuTTY, OpenSSH} clientstart; +    std::string display; +    std::string protocol_path; +    std::string program; +    std::vector<std::string> progs; +    bool compress; +    bool local; +    std::string protocol; +    std::string host; +    std::string user; +    std::string password; +    bool password_save; +    bool password_start; +    bool broadcast; +    bool indirect; +    std::string xdmcp_host; +    std::vector<std::string> xhosts; +    bool clipboard; +    bool no_access_control; +    std::string font_server; +    std::string extra_params; +    std::string extra_ssh; +    CConfig() : window(MultiWindow), client(NoClient), clientstart(NoXClient), display(""),  +                protocol_path(""), program("xeyes"), progs(PROG_NUMBER), compress(false), host(""), user(""), +                password(""), password_save(false), password_start(false), broadcast(false), +                indirect(false), xdmcp_host(""), xhosts(HOST_NUMBER), clipboard(true), no_access_control(false), +                font_server(), extra_params(), extra_ssh() {}; +    void Load(const char * filename); +    void Save(const char * filename); +}; + +#endif diff --git a/xorg-server/hw/xwin/xlaunch/main.cc b/xorg-server/hw/xwin/xlaunch/main.cc index 2247d3aaf..e4be475ee 100644 --- a/xorg-server/hw/xwin/xlaunch/main.cc +++ b/xorg-server/hw/xwin/xlaunch/main.cc @@ -34,6 +34,10 @@  #include <X11/Xlib.h> +#ifdef _MSC_VER +#define snprintf _snprintf +#endif +  /// @brief Send WM_ENDSESSION to all program windows.  /// This will shutdown the started xserver  BOOL CALLBACK KillWindowsProc(HWND hwnd, LPARAM lParam) @@ -489,7 +493,7 @@ class CMyWizard : public CWizard              return NULL;          } -        /// @brief Do the actual start of Xming and clients +        /// @brief Do the actual start of VCXsrv and clients  	void StartUp()  	{  	    std::string buffer; @@ -500,12 +504,12 @@ class CMyWizard : public CWizard  	    std::string display = "localhost" + display_id + ":0";  #ifdef _DEBUG -            // Debug only: Switch to Xming installation directory -	    SetCurrentDirectory("C:\\Programme\\Xming"); +            // Debug only: Switch to VCXsrv installation directory +	    SetCurrentDirectory("C:\\Programme\\vcxsrv");  #endif	     -            // Build Xming commandline -	    buffer = "Xming " + display_id + " "; +            // Build Xsrv commandline +	    buffer = "vcxsrv " + display_id + " ";  	    switch (config.window)  	    {  		case CConfig::MultiWindow: @@ -577,7 +581,7 @@ class CMyWizard : public CWizard  	    sic.cb = sizeof(sic);  	    ZeroMemory( &pic, sizeof(pic) ); -	    // Start Xming process.  +	    // Start VCXsrv process.   #ifdef _DEBUG  	    printf("%s\n", buffer.c_str());  #endif @@ -627,7 +631,7 @@ class CMyWizard : public CWizard  #ifdef _DEBUG  	    printf("killing process!\n");  #endif -            // Check if Xming is still running +            // Check if Xsrv is still running  	    DWORD exitcode;  	    GetExitCodeProcess(pi.hProcess, &exitcode);  	    unsigned counter = 0; @@ -636,7 +640,7 @@ class CMyWizard : public CWizard  		if (++counter > 10)  		    TerminateProcess(pi.hProcess, (DWORD)-1);  		else -		    // Shutdown Xming (the soft way!) +		    // Shutdown Xsrv (the soft way!)  		    EnumThreadWindows(pi.dwThreadId, KillWindowsProc, 0);  		Sleep(500);  		GetExitCodeProcess(pi.hProcess, &exitcode); diff --git a/xorg-server/hw/xwin/xlaunch/makefile b/xorg-server/hw/xwin/xlaunch/makefile new file mode 100644 index 000000000..345357d92 --- /dev/null +++ b/xorg-server/hw/xwin/xlaunch/makefile @@ -0,0 +1,32 @@ +INCLUDELIBFILES = window\$(OBJDIR)\window.lib \
 +                  $(MHMAKECONF)\libx11\src\$(OBJDIR)\libx11.lib \
 +                  $(MHMAKECONF)\libxcb\src\$(OBJDIR)\libxcb.lib \
 +                  $(MHMAKECONF)\libxau\$(OBJDIR)\libxau.lib \
 +                  $(MHMAKECONF)\libx11\src\xlibi18n\$(OBJDIR)\libi18n.lib \
 +                  $(MHMAKECONF)\libx11\modules\lc\xlocale\$(OBJDIR)\libxlocale.lib \
 +                  $(MHMAKECONF)\libx11\modules\lc\utf8\$(OBJDIR)\libxlcUTF8Load.lib \
 +                  $(MHMAKECONF)\libx11\modules\lc\gen\$(OBJDIR)\liblcGenConvLoad.lib \
 +                  $(MHMAKECONF)\libx11\modules\lc\def\$(OBJDIR)\libxlcDef.lib \
 +                  $(MHMAKECONF)\libx11\src\xkb\$(OBJDIR)\libxkb.lib \
 +                  $(MHMAKECONF)\libx11\modules\im\ximcp\$(OBJDIR)\libximcp.lib \
 +                  $(MHMAKECONF)\libx11\modules\om\generic\$(OBJDIR)\libxomGeneric.lib
 +
 +CSRCS=config.cc main.cc
 +
 +WINAPP = xlaunch
 +
 +RESOURCES = resources.rc
 +
 +$(OBJDIR)\%.res : resources\%.rc
 +	$(RC) $(RCFLAGS) $(RCDEFINES:%=-d "%") $(RCINCLUDES:%=-i "%") -Fo"$(relpath $@)" "$<"
 +
 +LIBDIRS=$(dir $(INCLUDELIBFILES))
 +
 +load_makefile $(LIBDIRS:%$(OBJDIR)\=%makefile MAKESERVER=$(MAKESERVER) DEBUG=$(DEBUG);)
 +
 +ifeq ($(DEBUG),1)
 +LINKLIBS += $(MHMAKECONF)\pthreads\pthreadVC2d.lib
 +else
 +LINKLIBS += $(MHMAKECONF)\pthreads\pthreadVC2.lib
 +endif
 +
 diff --git a/xorg-server/hw/xwin/xlaunch/window/makefile b/xorg-server/hw/xwin/xlaunch/window/makefile new file mode 100644 index 000000000..18a33e728 --- /dev/null +++ b/xorg-server/hw/xwin/xlaunch/window/makefile @@ -0,0 +1,4 @@ +CSRCS=dialog.cc util.cc window.cc wizard.cc
 +
 +LIBRARY = window
 +
 diff --git a/xorg-server/hw/xwin/xlaunch/window/util.h b/xorg-server/hw/xwin/xlaunch/window/util.h index cd21da657..2e8dab263 100644 --- a/xorg-server/hw/xwin/xlaunch/window/util.h +++ b/xorg-server/hw/xwin/xlaunch/window/util.h @@ -28,7 +28,7 @@  #include <windows.h>  #include <stdexcept> - +#include <string>    class win32_error : public std::runtime_error  { diff --git a/xorg-server/hw/xwin/xlaunch/window/wizard.h b/xorg-server/hw/xwin/xlaunch/window/wizard.h index a2361c51c..c576cc093 100644 --- a/xorg-server/hw/xwin/xlaunch/window/wizard.h +++ b/xorg-server/hw/xwin/xlaunch/window/wizard.h @@ -29,7 +29,6 @@  #include "dialog.h"
  #include <vector>
 -#define _WIN32_IE 0x0500
  #include <prsht.h>
  class CWizard : public CBaseDialog
 | 
