⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 init.c

📁 远程桌面连接工具
💻 C
📖 第 1 页 / 共 2 页
字号:
/* * init.c *//* *  Copyright (C) 1999 AT&T Laboratories Cambridge.  All Rights Reserved. * *  This is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This software is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this software; if not, write to the Free Software *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, *  USA. *//*Copyright (c) 1993  X ConsortiumPermission is hereby granted, free of charge, to any person obtaininga copy of this software and associated documentation files (the"Software"), to deal in the Software without restriction, includingwithout limitation the rights to use, copy, modify, merge, publish,distribute, sublicense, and/or sell copies of the Software, and topermit persons to whom the Software is furnished to do so, subject tothe following conditions:The above copyright notice and this permission notice shall be includedin all copies or substantial portions of the Software.THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESSOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OFMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OROTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OROTHER DEALINGS IN THE SOFTWARE.Except as contained in this notice, the name of the X Consortium shallnot be used in advertising or otherwise to promote the sale, use orother dealings in this Software without prior written authorizationfrom the X Consortium.*//* Use ``#define CORBA'' to enable CORBA control interface */#include <stdio.h>#include <unistd.h>#include <stdarg.h>#include <sys/types.h>#include <sys/socket.h>#include <netinet/in.h>#include <netdb.h>#include "X11/X.h"#define NEED_EVENTS#include "X11/Xproto.h"#include "X11/Xos.h"#include "scrnintstr.h"#include "servermd.h"#define PSZ 8#include "cfb.h"#include "mibstore.h"#include "colormapst.h"#include "gcstruct.h"#include "input.h"#include "mipointer.h"#include "dixstruct.h"#include "propertyst.h"#include <Xatom.h>#include <errno.h>#include <sys/param.h>#include "dix.h"#include "rfb.h"#include <time.h>#ifdef CORBA#include <vncserverctrl.h>#endif#define RFB_DEFAULT_WIDTH  640#define RFB_DEFAULT_HEIGHT 480#define RFB_DEFAULT_DEPTH  8#define RFB_DEFAULT_WHITEPIXEL 0#define RFB_DEFAULT_BLACKPIXEL 1rfbScreenInfo rfbScreen;int rfbGCIndex;static Bool initOutputCalled = FALSE;static Bool noCursor = FALSE;char *desktopName = "x11";char rfbThisHost[256];Atom VNC_LAST_CLIENT_ID;Atom VNC_CONNECT;static HWEventQueueType alwaysCheckForInput[2] = { 0, 1 };static HWEventQueueType *mieqCheckForInput[2];static char primaryOrder[4] = "";static int redBits, greenBits, blueBits;static Bool rfbScreenInit(int index, ScreenPtr pScreen, int argc,			  char **argv);static int rfbKeybdProc(DeviceIntPtr pDevice, int onoff);static int rfbMouseProc(DeviceIntPtr pDevice, int onoff);static Bool CheckDisplayNumber(int n);static Bool rfbAlwaysTrue();static char *rfbAllocateFramebufferMemory(rfbScreenInfoPtr prfb);static Bool rfbCursorOffScreen(ScreenPtr *ppScreen, int *x, int *y);static void rfbCrossScreen(ScreenPtr pScreen, Bool entering);static void rfbClientStateChange(CallbackListPtr *, pointer myData,				 pointer client);static miPointerScreenFuncRec rfbPointerCursorFuncs = {    rfbCursorOffScreen,    rfbCrossScreen,    miPointerWarpCursor};int inetdSock = -1;static char inetdDisplayNumStr[10];/* Interface address to bind to. */struct in_addr interface;/* * ddxProcessArgument is our first entry point and will be called at the * very start for each argument.  It is not called again on server reset. */intddxProcessArgument (argc, argv, i)    int argc;    char *argv[];    int i;{    static Bool firstTime = TRUE;    if (firstTime)    {	rfbScreen.width  = RFB_DEFAULT_WIDTH;	rfbScreen.height = RFB_DEFAULT_HEIGHT;	rfbScreen.depth  = RFB_DEFAULT_DEPTH;	rfbScreen.blackPixel = RFB_DEFAULT_BLACKPIXEL;	rfbScreen.whitePixel = RFB_DEFAULT_WHITEPIXEL;	rfbScreen.pfbMemory = NULL;	gethostname(rfbThisHost, 255);	interface.s_addr = htonl (INADDR_ANY);	firstTime = FALSE;    }    if (strcmp (argv[i], "-geometry") == 0)	/* -geometry WxH */    {	if (i + 1 >= argc) UseMsg();	if (sscanf(argv[i+1],"%dx%d",		   &rfbScreen.width,&rfbScreen.height) != 2) {	    ErrorF("Invalid geometry %s\n", argv[i+1]);	    UseMsg();	}#ifdef CORBA	screenWidth= rfbScreen.width;	screenHeight= rfbScreen.height;#endif	return 2;    }    if (strcmp (argv[i], "-depth") == 0)	/* -depth D */    {	if (i + 1 >= argc) UseMsg();	rfbScreen.depth = atoi(argv[i+1]);#ifdef CORBA	screenDepth= rfbScreen.depth;#endif	return 2;    }    if (strcmp (argv[i], "-pixelformat") == 0) {	if (i + 1 >= argc) UseMsg();	if (sscanf(argv[i+1], "%3s%1d%1d%1d", primaryOrder,		   &redBits, &greenBits, &blueBits) < 4) {	    ErrorF("Invalid pixel format %s\n", argv[i+1]);	    UseMsg();	}	if (strcasecmp(primaryOrder, "bgr") == 0) {	    int tmp = redBits;	    redBits = blueBits;	    blueBits = tmp;	} else if (strcasecmp(primaryOrder, "rgb") != 0) {	    ErrorF("Invalid pixel format %s\n", argv[i+1]);	    UseMsg();	}	return 2;    }    if (strcmp (argv[i], "-blackpixel") == 0) {	/* -blackpixel n */	if (i + 1 >= argc) UseMsg();	rfbScreen.blackPixel = atoi(argv[i+1]);	return 2;    }    if (strcmp (argv[i], "-whitepixel") == 0) {	/* -whitepixel n */	if (i + 1 >= argc) UseMsg();	rfbScreen.whitePixel = atoi(argv[i+1]);	return 2;    }    if (strcmp(argv[i], "-udpinputport") == 0) { /* -udpinputport port */	if (i + 1 >= argc) UseMsg();	udpPort = atoi(argv[i+1]);	return 2;    }    if (strcmp(argv[i], "-rfbport") == 0) {	/* -rfbport port */	if (i + 1 >= argc) UseMsg();	rfbPort = atoi(argv[i+1]);	return 2;    }    if (strcmp(argv[i], "-rfbwait") == 0) {	/* -rfbwait ms */	if (i + 1 >= argc) UseMsg();	rfbMaxClientWait = atoi(argv[i+1]);	return 2;    }    if (strcmp(argv[i], "-nocursor") == 0) {	noCursor = TRUE;	return 1;    }    if (strcmp(argv[i], "-rfbauth") == 0) {	/* -rfbauth passwd-file */	if (i + 1 >= argc) UseMsg();	rfbAuthPasswdFile = argv[i+1];	return 2;    }    if (strcmp(argv[i], "-httpd") == 0) {	if (i + 1 >= argc) UseMsg();	httpDir = argv[i+1];	return 2;    }    if (strcmp(argv[i], "-httpport") == 0) {	if (i + 1 >= argc) UseMsg();	httpPort = atoi(argv[i+1]);	return 2;    }    if (strcmp(argv[i], "-deferupdate") == 0) {	/* -deferupdate ms */	if (i + 1 >= argc) UseMsg();	rfbDeferUpdateTime = atoi(argv[i+1]);	return 2;    }    if (strcmp(argv[i], "-economictranslate") == 0) {	rfbEconomicTranslate = TRUE;	return 1;    }    if (strcmp(argv[i], "-lazytight") == 0) {	rfbTightDisableGradient = TRUE;	return 1;    }    if (strcmp(argv[i], "-desktop") == 0) {	/* -desktop desktop-name */	if (i + 1 >= argc) UseMsg();	desktopName = argv[i+1];	return 2;    }    if (strcmp(argv[i], "-alwaysshared") == 0) {	rfbAlwaysShared = TRUE;	return 1;    }    if (strcmp(argv[i], "-nevershared") == 0) {	rfbNeverShared = TRUE;	return 1;    }    if (strcmp(argv[i], "-dontdisconnect") == 0) {	rfbDontDisconnect = TRUE;	return 1;    }    /* Run server in view-only mode - Ehud Karni SW */    if (strcmp(argv[i], "-viewonly") == 0) {	rfbViewOnly = TRUE;	return 1;    }    if (strcmp(argv[i], "-localhost") == 0) {	interface.s_addr = htonl (INADDR_LOOPBACK);	return 1;    }    if (strcmp(argv[i], "-interface") == 0) {	/* -interface ipaddr */	struct in_addr got;	unsigned long octet;	char *p, *end;	int q;	if (i + 1 >= argc) {	    UseMsg();	    return 2;	}	if (interface.s_addr != htonl (INADDR_ANY)) {	    /* Already set (-localhost?). */	    return 2;	}	p = argv[i + 1];	for (q = 0; q < 4; q++) {	    octet = strtoul (p, &end, 10);	    if (p == end || octet > 255) {		UseMsg ();		return 2;	    }	    if (q < 3 && *end != '.' ||	        q == 3 && *end != '\0') {		UseMsg ();		return 2;	    }	    got.s_addr = (got.s_addr << 8) | octet;	    p = end + 1;	}	interface.s_addr = htonl (got.s_addr);	return 2;    }    if (strcmp(argv[i], "-inetd") == 0) {	/* -inetd */ 	int n;	for (n = 1; n < 100; n++) {	    if (CheckDisplayNumber(n))		break;	}	if (n >= 100)	    FatalError("-inetd: couldn't find free display number");	sprintf(inetdDisplayNumStr, "%d", n);	display = inetdDisplayNumStr;	/* fds 0, 1 and 2 (stdin, out and err) are all the same socket to the           RFB client.  OsInit() closes stdout and stdin, and we don't want           stderr to go to the RFB client, so make the client socket 3 and           close stderr.  OsInit() will redirect stderr logging to an           appropriate log file or /dev/null if that doesn't work. */	dup2(0,3);	inetdSock = 3;	close(2);	return 1;    }    if (strcmp(argv[i], "-compatiblekbd") == 0) {	compatibleKbd = TRUE;	return 1;    }    if (strcmp(argv[i], "-version") == 0) {	ErrorF("Xvnc version %s\n", XVNCRELEASE);	exit(0);    }    if (inetdSock != -1 && argv[i][0] == ':') {	FatalError("can't specify both -inetd and :displaynumber");    }    return 0;}/* * InitOutput is called every time the server resets.  It should call * AddScreen for each screen (but we only ever have one), and in turn this * will call rfbScreenInit. */voidInitOutput(screenInfo, argc, argv)    ScreenInfo *screenInfo;    int argc;    char **argv;{    initOutputCalled = TRUE;    rfbLog("Xvnc version %s\n", XVNCRELEASE);    rfbLog("Copyright (C) 2000-2009 TightVNC Group\n");    rfbLog("Copyright (C) 1999 AT&T Laboratories Cambridge\n");    rfbLog("All Rights Reserved.\n");    rfbLog("See http://www.tightvnc.com/ for information on TightVNC\n");    rfbLog("Desktop name '%s' (%s:%s)\n",desktopName,rfbThisHost,display);    rfbLog("Protocol versions supported: 3.3, 3.7, 3.8, 3.7t, 3.8t\n");    VNC_LAST_CLIENT_ID = MakeAtom("VNC_LAST_CLIENT_ID",				  strlen("VNC_LAST_CLIENT_ID"), TRUE);    VNC_CONNECT = MakeAtom("VNC_CONNECT", strlen("VNC_CONNECT"), TRUE);    rfbInitSockets();    if (inetdSock == -1)	httpInitSockets();   #ifdef CORBA    initialiseCORBA(argc, argv, desktopName);#endif    /* initialize pixmap formats */    screenInfo->imageByteOrder = IMAGE_BYTE_ORDER;    screenInfo->bitmapScanlineUnit = BITMAP_SCANLINE_UNIT;    screenInfo->bitmapScanlinePad = BITMAP_SCANLINE_PAD;    screenInfo->bitmapBitOrder = BITMAP_BIT_ORDER;    screenInfo->numPixmapFormats = 2;    screenInfo->formats[0].depth = 1;    screenInfo->formats[0].bitsPerPixel = 1;    screenInfo->formats[0].scanlinePad = BITMAP_SCANLINE_PAD;    screenInfo->formats[1].depth = rfbScreen.depth;    screenInfo->formats[1].bitsPerPixel = rfbBitsPerPixel(rfbScreen.depth);    screenInfo->formats[1].scanlinePad = BITMAP_SCANLINE_PAD;    rfbGCIndex = AllocateGCPrivateIndex();    if (rfbGCIndex < 0) {	FatalError("InitOutput: AllocateGCPrivateIndex failed\n");    }    if (!AddCallback(&ClientStateCallback, rfbClientStateChange, NULL)) {	rfbLog("InitOutput: AddCallback failed\n");	return;    }    /* initialize screen */    if (AddScreen(rfbScreenInit, argc, argv) == -1) {	FatalError("Couldn't add screen");    }}static BoolrfbScreenInit(index, pScreen, argc, argv)    int index;    ScreenPtr pScreen;    int argc;    char ** argv;{    rfbScreenInfoPtr prfb = &rfbScreen;    int dpix = 75, dpiy = 75;    int ret;    char *pbits;    VisualPtr vis;    extern int monitorResolution;    if (monitorResolution != 0) {	dpix = monitorResolution;	dpiy = monitorResolution;    }    prfb->paddedWidthInBytes = PixmapBytePad(prfb->width, prfb->depth);    prfb->bitsPerPixel = rfbBitsPerPixel(prfb->depth);    pbits = rfbAllocateFramebufferMemory(prfb);    if (!pbits) return FALSE;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -