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

📄 tkunixwm.c

📁 linux系统下的音频通信
💻 C
📖 第 1 页 / 共 5 页
字号:
	}	if (*argv[3] == '\0') {	    wmPtr->sizeHintsFlags &= ~PAspect;	} else {	    if ((Tcl_GetInt(interp, argv[3], &numer1) != TCL_OK)		    || (Tcl_GetInt(interp, argv[4], &denom1) != TCL_OK)		    || (Tcl_GetInt(interp, argv[5], &numer2) != TCL_OK)		    || (Tcl_GetInt(interp, argv[6], &denom2) != TCL_OK)) {		return TCL_ERROR;	    }	    if ((numer1 <= 0) || (denom1 <= 0) || (numer2 <= 0) ||		    (denom2 <= 0)) {		interp->result = "aspect number can't be <= 0";		return TCL_ERROR;	    }	    wmPtr->minAspect.x = numer1;	    wmPtr->minAspect.y = denom1;	    wmPtr->maxAspect.x = numer2;	    wmPtr->maxAspect.y = denom2;	    wmPtr->sizeHintsFlags |= PAspect;	}	wmPtr->flags |= WM_UPDATE_SIZE_HINTS;	goto updateGeom;    } else if ((c == 'c') && (strncmp(argv[1], "client", length) == 0)	    && (length >= 2)) {	if ((argc != 3) && (argc != 4)) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " client window ?name?\"",		    (char *) NULL);	    return TCL_ERROR;	}	if (argc == 3) {	    if (wmPtr->clientMachine != NULL) {		interp->result = wmPtr->clientMachine;	    }	    return TCL_OK;	}	if (argv[3][0] == 0) {	    if (wmPtr->clientMachine != NULL) {		ckfree((char *) wmPtr->clientMachine);		wmPtr->clientMachine = NULL;		if (!(wmPtr->flags & WM_NEVER_MAPPED)) {		    XDeleteProperty(winPtr->display, wmPtr->wrapperPtr->window,			    Tk_InternAtom((Tk_Window) winPtr,			    "WM_CLIENT_MACHINE"));		}	    }	    return TCL_OK;	}	if (wmPtr->clientMachine != NULL) {	    ckfree((char *) wmPtr->clientMachine);	}	wmPtr->clientMachine = (char *)		ckalloc((unsigned) (strlen(argv[3]) + 1));	strcpy(wmPtr->clientMachine, argv[3]);	if (!(wmPtr->flags & WM_NEVER_MAPPED)) {	    XTextProperty textProp;	    if (XStringListToTextProperty(&wmPtr->clientMachine, 1, &textProp)		    != 0) {		XSetWMClientMachine(winPtr->display, wmPtr->wrapperPtr->window,			&textProp);		XFree((char *) textProp.value);	    }	}    } else if ((c == 'c') && (strncmp(argv[1], "colormapwindows", length) == 0)	    && (length >= 3)) {	Window *cmapList;	TkWindow *winPtr2;	int count, i, windowArgc, gotToplevel;	char buffer[20], **windowArgv;	if ((argc != 3) && (argc != 4)) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " colormapwindows window ?windowList?\"",		    (char *) NULL);	    return TCL_ERROR;	}	Tk_MakeWindowExist((Tk_Window) winPtr);	if (wmPtr->wrapperPtr == NULL) {	    CreateWrapper(wmPtr);	}	if (argc == 3) {	    if (XGetWMColormapWindows(winPtr->display,		    wmPtr->wrapperPtr->window, &cmapList, &count) == 0) {		return TCL_OK;	    }	    for (i = 0; i < count; i++) {		if ((i == (count-1))			&& (wmPtr->flags & WM_ADDED_TOPLEVEL_COLORMAP)) {		    break;		}	        winPtr2  = (TkWindow *) Tk_IdToWindow(winPtr->display,			cmapList[i]);		if (winPtr2 == NULL) {		    sprintf(buffer, "0x%lx", cmapList[i]);		    Tcl_AppendElement(interp, buffer);		} else {		    Tcl_AppendElement(interp, winPtr2->pathName);		}	    }	    XFree((char *) cmapList);	    return TCL_OK;	}	if (Tcl_SplitList(interp, argv[3], &windowArgc, &windowArgv)		!= TCL_OK) {	    return TCL_ERROR;	}	cmapList = (Window *) ckalloc((unsigned)		((windowArgc+1)*sizeof(Window)));	gotToplevel = 0;	for (i = 0; i < windowArgc; i++) {	    winPtr2 = (TkWindow *) Tk_NameToWindow(interp, windowArgv[i],		    tkwin);	    if (winPtr2 == NULL) {		ckfree((char *) cmapList);		ckfree((char *) windowArgv);		return TCL_ERROR;	    }	    if (winPtr2 == winPtr) {		gotToplevel = 1;	    }	    if (winPtr2->window == None) {		Tk_MakeWindowExist((Tk_Window) winPtr2);	    }	    cmapList[i] = winPtr2->window;	}	if (!gotToplevel) {	    wmPtr->flags |= WM_ADDED_TOPLEVEL_COLORMAP;	    cmapList[windowArgc] = wmPtr->wrapperPtr->window;	    windowArgc++;	} else {	    wmPtr->flags &= ~WM_ADDED_TOPLEVEL_COLORMAP;	}	wmPtr->flags |= WM_COLORMAPS_EXPLICIT;	XSetWMColormapWindows(winPtr->display, wmPtr->wrapperPtr->window,		cmapList, windowArgc);	ckfree((char *) cmapList);	ckfree((char *) windowArgv);	return TCL_OK;    } else if ((c == 'c') && (strncmp(argv[1], "command", length) == 0)	    && (length >= 3)) {	int cmdArgc;	char **cmdArgv;	if ((argc != 3) && (argc != 4)) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " command window ?value?\"",		    (char *) NULL);	    return TCL_ERROR;	}	if (argc == 3) {	    if (wmPtr->cmdArgv != NULL) {		interp->result = Tcl_Merge(wmPtr->cmdArgc, wmPtr->cmdArgv);		interp->freeProc = TCL_DYNAMIC;	    }	    return TCL_OK;	}	if (argv[3][0] == 0) {	    if (wmPtr->cmdArgv != NULL) {		ckfree((char *) wmPtr->cmdArgv);		wmPtr->cmdArgv = NULL;		if (!(wmPtr->flags & WM_NEVER_MAPPED)) {		    XDeleteProperty(winPtr->display, wmPtr->wrapperPtr->window,			    Tk_InternAtom((Tk_Window) winPtr, "WM_COMMAND"));		}	    }	    return TCL_OK;	}	if (Tcl_SplitList(interp, argv[3], &cmdArgc, &cmdArgv) != TCL_OK) {	    return TCL_ERROR;	}	if (wmPtr->cmdArgv != NULL) {	    ckfree((char *) wmPtr->cmdArgv);	}	wmPtr->cmdArgc = cmdArgc;	wmPtr->cmdArgv = cmdArgv;	if (!(wmPtr->flags & WM_NEVER_MAPPED)) {	    XSetCommand(winPtr->display, wmPtr->wrapperPtr->window,		    cmdArgv, cmdArgc);	}    } else if ((c == 'd') && (strncmp(argv[1], "deiconify", length) == 0)) {	if (argc != 3) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " deiconify window\"", (char *) NULL);	    return TCL_ERROR;	}	if (wmPtr->iconFor != NULL) {	    Tcl_AppendResult(interp, "can't deiconify ", argv[2],		    ": it is an icon for ", Tk_PathName(wmPtr->iconFor),		    (char *) NULL);	    return TCL_ERROR;	}	wmPtr->hints.initial_state = NormalState;	wmPtr->withdrawn = 0;	if (wmPtr->flags & WM_NEVER_MAPPED) {	    return TCL_OK;	}	UpdateHints(winPtr);	Tk_MapWindow((Tk_Window) winPtr);    } else if ((c == 'f') && (strncmp(argv[1], "focusmodel", length) == 0)	    && (length >= 2)) {	if ((argc != 3) && (argc != 4)) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " focusmodel window ?active|passive?\"",		    (char *) NULL);	    return TCL_ERROR;	}	if (argc == 3) {	    interp->result = wmPtr->hints.input ? "passive" : "active";	    return TCL_OK;	}	c = argv[3][0];	length = strlen(argv[3]);	if ((c == 'a') && (strncmp(argv[3], "active", length) == 0)) {	    wmPtr->hints.input = False;	} else if ((c == 'p') && (strncmp(argv[3], "passive", length) == 0)) {	    wmPtr->hints.input = True;	} else {	    Tcl_AppendResult(interp, "bad argument \"", argv[3],		    "\": must be active or passive", (char *) NULL);	    return TCL_ERROR;	}	UpdateHints(winPtr);    } else if ((c == 'f') && (strncmp(argv[1], "frame", length) == 0)	    && (length >= 2)) {	Window window;	if (argc != 3) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " frame window\"", (char *) NULL);	    return TCL_ERROR;	}	window = wmPtr->reparent;	if (window == None) {	    window = Tk_WindowId((Tk_Window) winPtr);	}	sprintf(interp->result, "0x%x", (unsigned int) window);    } else if ((c == 'g') && (strncmp(argv[1], "geometry", length) == 0)	    && (length >= 2)) {	char xSign, ySign;	int width, height;	if ((argc != 3) && (argc != 4)) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " geometry window ?newGeometry?\"",		    (char *) NULL);	    return TCL_ERROR;	}	if (argc == 3) {	    xSign = (wmPtr->flags & WM_NEGATIVE_X) ? '-' : '+';	    ySign = (wmPtr->flags & WM_NEGATIVE_Y) ? '-' : '+';	    if (wmPtr->gridWin != NULL) {		width = wmPtr->reqGridWidth + (winPtr->changes.width			- winPtr->reqWidth)/wmPtr->widthInc;		height = wmPtr->reqGridHeight + (winPtr->changes.height			- winPtr->reqHeight)/wmPtr->heightInc;	    } else {		width = winPtr->changes.width;		height = winPtr->changes.height;	    }	    sprintf(interp->result, "%dx%d%c%d%c%d", width, height,		    xSign, wmPtr->x, ySign, wmPtr->y);	    return TCL_OK;	}	if (*argv[3] == '\0') {	    wmPtr->width = -1;	    wmPtr->height = -1;	    goto updateGeom;	}	return ParseGeometry(interp, argv[3], winPtr);    } else if ((c == 'g') && (strncmp(argv[1], "grid", length) == 0)	    && (length >= 3)) {	int reqWidth, reqHeight, widthInc, heightInc;	if ((argc != 3) && (argc != 7)) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " grid window ?baseWidth baseHeight ",		    "widthInc heightInc?\"", (char *) NULL);	    return TCL_ERROR;	}	if (argc == 3) {	    if (wmPtr->sizeHintsFlags & PBaseSize) {		sprintf(interp->result, "%d %d %d %d", wmPtr->reqGridWidth,			wmPtr->reqGridHeight, wmPtr->widthInc,			wmPtr->heightInc);	    }	    return TCL_OK;	}	if (*argv[3] == '\0') {	    /*	     * Turn off gridding and reset the width and height	     * to make sense as ungridded numbers.	     */	    wmPtr->sizeHintsFlags &= ~(PBaseSize|PResizeInc);	    if (wmPtr->width != -1) {		wmPtr->width = winPtr->reqWidth + (wmPtr->width			- wmPtr->reqGridWidth)*wmPtr->widthInc;		wmPtr->height = winPtr->reqHeight + (wmPtr->height			- wmPtr->reqGridHeight)*wmPtr->heightInc;	    }	    wmPtr->widthInc = 1;	    wmPtr->heightInc = 1;	} else {	    if ((Tcl_GetInt(interp, argv[3], &reqWidth) != TCL_OK)		    || (Tcl_GetInt(interp, argv[4], &reqHeight) != TCL_OK)		    || (Tcl_GetInt(interp, argv[5], &widthInc) != TCL_OK)		    || (Tcl_GetInt(interp, argv[6], &heightInc) != TCL_OK)) {		return TCL_ERROR;	    }	    if (reqWidth < 0) {		interp->result = "baseWidth can't be < 0";		return TCL_ERROR;	    }	    if (reqHeight < 0) {		interp->result = "baseHeight can't be < 0";		return TCL_ERROR;	    }	    if (widthInc < 0) {		interp->result = "widthInc can't be < 0";		return TCL_ERROR;	    }	    if (heightInc < 0) {		interp->result = "heightInc can't be < 0";		return TCL_ERROR;	    }	    Tk_SetGrid((Tk_Window) winPtr, reqWidth, reqHeight, widthInc,		    heightInc);	}	wmPtr->flags |= WM_UPDATE_SIZE_HINTS;	goto updateGeom;    } else if ((c == 'g') && (strncmp(argv[1], "group", length) == 0)	    && (length >= 3)) {	Tk_Window tkwin2;	WmInfo *wmPtr2;	if ((argc != 3) && (argc != 4)) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " group window ?pathName?\"",		    (char *) NULL);	    return TCL_ERROR;	}	if (argc == 3) {	    if (wmPtr->hints.flags & WindowGroupHint) {		interp->result = wmPtr->leaderName;	    }	    return TCL_OK;	}	if (*argv[3] == '\0') {	    wmPtr->hints.flags &= ~WindowGroupHint;	    if (wmPtr->leaderName != NULL) {		ckfree(wmPtr->leaderName);	    }	    wmPtr->leaderName = NULL;	} else {	    tkwin2 = Tk_NameToWindow(interp, argv[3], tkwin);	    if (tkwin2 == NULL) {		return TCL_ERROR;	    }	    while (!Tk_IsTopLevel(tkwin2)) {		/*		 * Ensure that the group leader is actually a Tk toplevel.		 */		tkwin2 = Tk_Parent(tkwin2);	    }	    Tk_MakeWindowExist(tkwin2);	    wmPtr2 = ((TkWindow *) tkwin2)->wmInfoPtr;	    if (wmPtr2->wrapperPtr == NULL) {		CreateWrapper(wmPtr2);	    }	    wmPtr->hints.window_group = Tk_WindowId(wmPtr2->wrapperPtr);	    wmPtr->hints.flags |= WindowGroupHint;	    wmPtr->leaderName = ckalloc((unsigned) (strlen(argv[3])+1));	    strcpy(wmPtr->leaderName, argv[3]);	}	UpdateHints(winPtr);    } else if ((c == 'i') && (strncmp(argv[1], "iconbitmap", length) == 0)	    && (length >= 5)) {	Pixmap pixmap;	if ((argc != 3) && (argc != 4)) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " iconbitmap window ?bitmap?\"",		    (char *) NULL);	    return TCL_ERROR;	}	if (argc == 3) {	    if (wmPtr->hints.flags & IconPixmapHint) {		interp->result = Tk_NameOfBitmap(winPtr->display,			wmPtr->hints.icon_pixmap);	    }	    return TCL_OK;	}	if (*argv[3] == '\0') {	    if (wmPtr->hints.icon_pixmap != None) {		Tk_FreeBitmap(winPtr->display, wmPtr->hints.icon_pixmap);		wmPtr->hints.icon_pixmap = None;	    }	    wmPtr->hints.flags &= ~IconPixmapHint;	} else {	    pixmap = Tk_GetBitmap(interp, (Tk_Window) winPtr,		    Tk_GetUid(argv[3]));	    if (pixmap == None) {		return TCL_ERROR;	    }	    wmPtr->hints.icon_pixmap = pixmap;	    wmPtr->hints.flags |= IconPixmapHint;	}	UpdateHints(winPtr);    } else if ((c == 'i') && (strncmp(argv[1], "iconify", length) == 0)	    && (length >= 5)) {	if (argc != 3) {	    Tcl_AppendResult(interp, "wrong # arguments: must be \"",		    argv[0], " iconify window\"", (char *) NULL);	    return TCL_ERROR;	}

⌨️ 快捷键说明

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