第12章 资讯与状态程式
第参部 定制系统
第12章 资讯与状态程式
在本章,我们将讨论一些提供视窗系统本身资讯和目前状态的程式。
这包括了检查系统上视窗各种性质 (property) 的工具,和一个观察X
事件结构是如何工作的程式。
这些程式有下列用途:
.当你使用系统时,这些工具程式所提供有关系统内部组织和操作的资讯,
可以帮助你了解发生了什麽事。
.当你要做某种处理时,可以藉著所给的资讯来确认系统的组件。(例如
你必须知道一个视窗的window-id,才可以用xwd 来倾印它。)
.你将经常把从这些工具获得的资讯,当成定制系统工具程式的输入(稍
後几章会讨论)。
12.1 列出你的Xserver的特徵 -- xdpyinfo
xdpyinfo列出有关你的Xserver和server所控制萤幕之各种项目的资讯,
一个典型的输出见图12-1(一个server在Sun 3/50单色工作站上执行的结果)。
┌--------------------------------------┐
│ p134 fig 12.1 │
│ │
│ 图12-1 典型的xdpyinfo工具程式的输出 │
└--------------------------------------┘
12.2 获取有关视窗的资讯
有三个程式可以提供目前在你显示器上视窗的资讯。它们是从不同的角度
看系统:
1. 列印视窗的阶层 -- xlswins
2. 对单一视窗详细的资讯 -- xwininfo
3. 列出视窗的性质 -- xprop
12.2.1 列印视窗的阶层 -- xlswins
在第一部曾经提过,所有在系统上的视窗被安排成树状的阶层,根视窗
(也叫背景(background)视窗)在最上层,在其下才是应用视窗,每一个应用
视窗可以拥有它自己的子视窗阶层。
xlswins 列印出这个树状结构,从根视窗或所指定的视窗起至其下所有的
树状结构,对每一个视窗,xlswins 列出视窗的window-id 并用括弧括住它的
名称(如果有的话),子视窗则在下面的几行依序以缩入(indent)两格的方式
列出。下面的图对xman应用程式列出三个不同子树的输出,藉以展示xlswins
如何剖析系统的结构。
图12-2a 是xman主选单的树。你可以看到在应用视窗(0X600011)中含有另一
个视窗(0X600012),而(0X600012)又包含了四个视窗,不需要知道原始程式,
你也可以猜得到是一种视窗包含著视窗,而对子视窗做某种管理的情况。
图12-2b 是xman手册页(manpage) 视窗的树。比上一个例子复杂一些,而且
也无法在确定是否在这一页手册页中总共就只有这麽多视窗和子视窗。所以 ...
图12-2c 这是xlswins 更详细的输出,比上一个例子需要在命令列中多加
一个 -l 的选项,多出来的讯息为巢状的深度(第几层树)、相对於父视窗的
几何座标和大小、和视窗左上角距离根视窗的座标(也就是萤幕上的绝对座标)
,有了这些视窗的座标,你就能了解它们在萤幕上的位置,如果你还是搞不太
清楚,可以执行xwd ,指定xlswins 所输出的window-id ,在本图,我们发觉
视窗(0X60005d)是高而窄的,所以可能是一个卷动棒。我们可以试著用命令:
xwd -id 0x60005d | xwud
结果的确 xman 卷动棒的图形出现了,这个命令我们在9.2.1 节有提过(只不
过这一次我们不把输出送到档案,而利用导管 (pipe) 的技巧直接当成另一程
式的输入。)你可以用这种方法分析任何视窗。
┌------------------------------------┐
│ p136 fig 12.2 │
│ │
│ 图12-2 三个xlswins 的输出 │
└------------------------------------┘
注意:并非所有的视窗都可列印出资讯,如果你碰到这种无资讯可供列印视窗
,你将获得类似下面的讯息:
x Protocol error: BadMatch, invalid parameter
attributes
Major opcode of failed request: 73 (X_GetImage)
为了篇幅的关系,我们只列出了完整xlswins 输出的三个小部份。如果在
你自己已经有好几个应用程式的系统上,你将可以看到uwm 和xterm 选单所相
关的子树,或者是与 xmh和 xedit 的命令按钮相关的子树。
12.2.2 关於单一视窗的详细资讯 -- xwininfo
xwininfo能够针对特定的视窗给你大量的资讯,你可以藉著命令列的选项
告诉xwininfo你要哪一部份的资讯。图12-3包含完整的列印输出(用选项-all)
┌------------------------------------┐
│ p138 fig 12.3 │
│ │
│ 图12-3 典型的xwininfo输出 │
└------------------------------------┘
你可以用和xwd 相同的方法来指定你感兴趣的视窗:
.交谈式(预设):开始时,xwininfo给你一个十字线游标,你可以将
它移到你所需的视窗再碰触滑鼠按钮。
.使用命令列选项:你可以用选项-root 指定根视窗,或用选项-id
window-id 指定其它的视窗。
你所看到的资讯可分为以下几类:
视窗的window-id :window-id 是视窗系统识别每一个视窗的参考,就如
同先前所看到的,几个程式(包含xwininfo它本身)给你一个数字代
表window-id 。例如你要倾印一个视窗,你可以先执行xwininfo得到
它的window-id,然後将此window-id 做为xwd 的id选项之引数。
阶层的资讯:你可以看到这个视窗的父视窗的id,几个子视窗的id,以及
根视窗的id,在xlswins 中可得到相同的资讯,但在这里只能得到最
近一层子视窗的id,并非整个子树。
几何细节:视窗的大小和位置,以及它的四个角的位置。
和server有关的重建构参数:像”gravity ”和”backing store ”这
些状态(state) ,当视窗改变大小或从被遮盖的状态下重新显
露出来时,server需要用到这些参数,这些参数你自己不会用到,
但可藉它了解系统如何运作。
事件参数:这些参数也是给server而非给使用者用的。
视窗管理器资讯:在系统概观中,我们曾经提过应用程式藉著给视窗管理
器一些提示”hints ”来达成通讯(这些提示包括应用程式所希望视
窗的大小,以及重定大小时的限制等。),xwininfo在这个部份的输
出便是告诉你这些”提示”的资料。Program supplied location 为
应用程式建议它自己应该摆哪里。如果你曾给过位置,不论是在命令
列或resource file ,都会在 User supplied location 出现,在视
窗大小方面同理可推,resize increments 解释了为什麽有些视窗(
例如xterm 和xfd )不能把大小定为任意数目的像素,因为应用程式
已经告诉了视窗管理器在重定大小时按多少个像素的倍数放大或缩小
(xterm 和xfd 它们的大小和所使用的字型有关),你也可以由这个
参数知道目前视窗的位置,所以稍後你可以在同一位置上重建它。
12.2.3 列出视窗的性质 -- xprop
如同我们在系统概观所提及的,一个”性质”(property)是指一小段有关
视窗的资料,xprop 让你列出一个特定视窗的所有”性质”,你也可以列印
一个字型的性质。
你可以经由常用的方式来选择视窗(碰触滑鼠按钮或使用-root 或-id 选项)
,如果是指定字型,则用选项-font fontname。
显示出来的格式为:对每一个性质,均有一个性质名称,在其後用小括弧
括住的为性质的型态或格式,最後则为性质的值。大部份你所看到的性质型态
为STRING,性质的值用” ”括起来,其它的性质型态的格式是专属的,从
性质的值很容易了解它的意义,对字型显示的格式稍有不同,它没有性质型态,
但性质的值意义也很明显。
注意:xprop 的输出相当的复杂,我们并不需要了解其所有的内容,端视需要而
定。
以下让我们看看从应用视窗、根视窗、字型所获得不同的输出:
应用视窗的性质
图12-4为xprop 对一个应用视窗的输出,有些资讯你已经在xwininfo中看
到过,在此处你可以在名为WM_NORMAL_HINTS 和WM_HINTS的性质中看到。
┌------------------------------------┐
│ p140 fig 12.4 │
│ │
│ 图12-4 一个应用视窗的性质表列 │
└------------------------------------┘
其它的性质如下:
WM_COMMAND:执行启动这个应用程式的命令列,被切成一个个用双引号括起来的
单字。
WM_CLIENT_MACHINE :执行这个client应用程式的机器名称(这个例子应用程
式和server在同一部机器上执行,所以机器名称为venus 。)。
WM_CLASS:显示应用程式的instant name和class name,instant name是命令
列中-name 选项的值。
WM_ICON_NAME:应用程式的表徵图所要显示出来的名称(你的视窗管理器必须
能够支援方可)。
WM_NAME :很奇怪的,这不是应用程式的名称,而是由-title选项指定的视窗
标题名称,有些视窗管理器会把标题名称显示在应用视窗的标题
棒上。
注意:上述命令列中-name 和-title两个选项使用得很广,但它并非通用
(universal) 的选项,应用程式在撰写时必需要使用到X Toolkit(工
具箱)才能把这两个选项当成标准选项来用。(参见第15章)
根视窗的性质
图12-5是xprop 对根视窗的输出,显而易见的是,它不会含有任何视窗管
理器的性质,因为视窗管理器绝不可能重新建构根视窗。
┌------------------------------------┐
│ p141 fig 12.5 │
│ │
│ 图12-5 根视窗的性质表列 │
└------------------------------------┘
有趣的选项如下:
RESOURCE_MANAGER:这个根视窗性质是resource结构的输入源之一,我们将在
第11章详细地讨论它。
几个CUT_BUFFER:当你切取一段本文(做剪贴动作常用),这段被切取的本文
被放在一个切取缓冲器(cut buffer)中,这些缓冲器被当作是根
视窗的性质来储存,对於切取,缓冲器是循环使用的,例如上次
用5 号缓冲器,则下次用6 号,接下来7 号、0 号、1 号等等,
但是黏贴则一定使用上次切取动作所用的缓冲器。
字型性质
图12-6列出当我们指定*times*bold*-i-*-180-*的字型性质,大部份的资
讯我们都不需关心,你可能只对FULL_NAME 和POINT_SIZE有兴趣。
┌------------------------------------┐
│ p142 fig 12.6 │
│ │
│ 图12-6 字型的性质表列 │
└------------------------------------┘
12.3 观察X的事件 -- xev
”事件”或多或少驱动著整个视窗系统,所有的输入,不论是滑鼠或键盘,
均由”事件”来掌握,”事件”也被用来驱动视窗的重新建构和展现。xev 程
式让你看到当不同的动作发生时,会产生什麽”事件”,以及和”事件”有关
的资讯。
当xev 启动,它会建一个类似图12-7的视窗,而在这视窗中,会开始列出
类似图12-8的有关事件的细节部份。
┌------------------------------------┐
│ p143 fig 12.7 │
│ │
│ 图12-7 xev 视窗 │
└------------------------------------┘
┌------------------------------------┐
│ p143 fig 12.8 │
│ │
│ 图12-8 xev 的输出 │
└------------------------------------┘
由於 xev提供大量的系统内部操作细节,你如果想要”实验”系统,这是一个
很有用的程式,有两个说明手册上未提到的选项可以影响到xev 的行为:
-bs option:此选项改变xev 对server是否使用backing store (见第2章),
使用backing store 将减少曝光”事件”的次数(也就是减少应
用程式重新更新它自己视窗的次数),正确的选项内容为always,
whenmapped和notuseful 。
-s:使用save-unders (见第2章),也就是说,要求server保存那些被xev
的视窗遮盖之视窗的内容。
12.3.1 xev 和键盘
如果你将指标移入xev 视窗且按下你的键盘上的某一个键,则一个(或多
个)键盘”事件”会发生,”事件”的资讯包含了keycode 和keysym,这是最
容易观察你的机器上某一个键是什麽键码(keycode) 的方法:执行xev ,按一
个键,xev 便会给你资讯,这对定制你的键盘非常有用,见18章。
12.4 结论
本章所述的这些程式,让你观察系统的内部;获得它的操作细节;和它的
视窗及其它成员特定的资讯.对这些程式本身而言,它们能帮助你了解系统,
但它们最大的用途可能是用来连接那些定制系统的程式。以下的几章在说明如
何定制和设定你的系统,好让系统更适合你工作的习惯。
下一章讨论处理字型和颜色,及如何使用它们。