国际语言环境指南

定制现有的 prolog 文件并添加新的 prolog 文件

prolog 文件可分为两种主要类别:

PostScript 文件定制

PostScript 文件属于下列类别:

依赖于语言环境的 prolog 文件

prolog.ps 文件的目的是设置非通用字体。应用程序使用这些预定义 PostScript 字体名称进行打印。prolog 文件必须为桌面设置日历管理器和 mp 至少定义下面字体名称。

下列示例使用这些字体打印指定的特殊本地字符集:

100 100 moveto
/LC_Times-Roman findfont 24 scale font setfont(您的语言环境中的任何字符串)显示 

Solaris 本地化工具包为日语环境提供了一个样例 prolog.ps 文件。另外,此文件也可以在 /usr/openwin/lib/locale/ja/print/ 目录中找到。

下列示例说明如何在现有的 prolog.ps 中添加或更改复合字体。

%
(Foo-Fine) makecodeset12 
(Base-Font) makeEUCfont
%

假设您要定义一种称为 LC_Base-Font 的复合字体:

LC_Base-Font 是 Foo-Fine 和名为 Base-Font 的基准字体的复合字体。Foo-Fine 是包含本地字符集的字体。您不需要任何高深的 PostScript 知识就可以添加或更改字体。

对示例版本进行研究是创建 prolog.ps 文件的最好方法。在示例 prolog.ps 中,需要编写两个例程,即 makecodeset12 makeEUCfontMakecodeset12 设置本地字体编码信息。此例程可能会因语言环境的不同而不同。MakeEUCfont 将基准字体和区域字体合并为一个复合字体。prolog 文件的创建者应具有良好的 PostScript 知识,以便编写 makecodeset12makeEUCfont

prolog.ps 文件支持只保持向后兼容性。不要为一种语言环境的打印需要创建新的 prolog.ps 文件。请换而使用 mp.conf

prolog.ps 的路径为

/usr/openwin/lib/locale/$LANG/print/prolog.ps

通用 PostScript prolog 文件

通用 prolog 文件为 mp.common.ps

其它每个页面布局 prolog 文件都需要包含此文件。

mp.common.ps 文件位于 /usr/lib/lp/locale/C/mp/ 目录中,它包含一个 PostScript 例程以便将标准编码中的字体重新编码为 ISO 8859–1 编码。.reencodeISO 例程从打印布局 prolog 文件中调用以更改字体的编码。通常情况下,此 prolog 文件不需要任何定制。如果用户正在创建自己的 prolog 文件,请将环境变量 MP_PROLOGUE 设置为指向包含修改后的 prolog 文件的目录。

打印布局 prolog 文件

打印布局 prolog 文件、mp.*.ps 文件包含控制用于打印的页面布局的例程。除了为具有用户名、打印日期和页号的打印页提供标题和页脚外,这些 prolog 文件还可以提供其它信息。例如,prolog 文件可提供有效的打印区域尺寸以及打印所要使用的横向和纵向模式。

打印布局 prolog 文件为:

需要在每个 prolog 文件中定义一组标准函数。当新的打印页启动、某个打印页结束或新的列结束时这些函数即被调用。这些函数的实现定义了打印输出的打印属性。

下列 PostScript 变量被 mp(1) 程序在运行时定义。所有的打印布局文件都可以使用这些变量来打印动态信息,如 用户名 主题打印时间。 从变量获取的此信息通常出现在打印页的标题或页脚中。

用户

正在运行 mp 的用户的名称,可从系统 passwd 文件中获取。

MailFor

用于保存要打印的文章类型名称的变量。此变量的可能值为:

  • “Listing for” - 当输入为文本文件时

  • “Mail for” - 当输入为邮件文件时

  • “Article from” - 当输入为新闻组文章时

主题

从邮件和新闻标题中获取的主题。您可以使用 -s 选项将某个主题强迫为邮件和新闻文件以及正常的文本文件。

Timenow

出现在标题和页脚中的打印时间。此信息从 localtime() 函数中获取。

下列函数在打印布局 prolog 文件中实现。所有这些函数都可以使用子函数。

endpage

用法:page_number endpage

当到达打印页的底部时调用。此函数恢复页面的图形上下文并发出 “showpage” 命令。在某些 prolog 文件中,标题和页脚信息仅以逐页模式(而不是逐列模式)显示。您可以实现此函数以调用显示标题和页脚灰度级菱形的子函数。

newpage

用法: page_number newpage

当某个新页开始时要执行的例程或命令。设置横向打印模式、保存打印图形上下文和翻译页坐标是用于例程的一些函数。

endcol

用法: page_number col_number endcol

用于显示标题和页脚信息。移到新的打印位置,等等。

要添加新的打印布局 prolog 文件,您需要在打印布局 prolog 文件内显式定义下列变量。

NumCols

打印页中的列数。缺省值为 2。

PrintWidth

打印区域的宽度(以英寸为单位)。缺省值为 6。

PrintHeight

打印区域的高度(以英寸为单位)。缺省值为 9。

.xpr 文件定制

默认情况下,这些文件位于 /usr/lib/lp/locale/C/mp/ .xpr 文件与每个 PostScript prolog 布局文件相对应,mp.common.ps 除外。您可以通过定义 MP_PROLOGUE 环境变量来定义替换的 prolog 目录。

这些文件用作关键字/值对。以 # 开头的行被认为是注释。空格分隔不同的标记(除非显式进行说明)。每个 .xpr 文件的三个主要部分由下列关键字对绑定:

某些关键字/值对可用于这三个区域。下面分别描述每个区域。

STARTCOMMON/ENDCOMMON 关键字

出现在 STARTCOMMON 关键字之后并且在 ENDCOMMON 关键字之前的所有关键字/值对定义打印页的常规属性。通过使用“/”来分隔关键字的不同有效值。

ORIENTATION 0/1

“0”表示以纵向模式打印而“1”表示以横向模式打印。

PAGELENGTH 无符号整数

一个值,用于表示每个逻辑页的行数。

LINELENGTH 无符号整数

一个值,用于表示每行的单列字符数。

NUMCOLS 无符号整数

每个物理页的逻辑页数。

HDNGFONTSIZE 无符号整数

标题字体磅值(以小数点表示)。

BODYFONTSIZE 无符号整数

正文字体磅值(以小数点表示)。

PROLOGDPI 无符号整数

创建当前 .xpr 文件使用的每英寸点数比例。

YTEXTBOUNDARY 无符号整数

此 y 坐标确定了页或逻辑页(列)中文本打印的边界。此边界还可以用于检查文本打印是否发生在预期的区域内。在复杂文本布局和 EUC 打印时需要此边界,这是因为从相应的字体中获取的字符高度信息有可能是错的。

STARTTEXT 无符号整数 无符号整数

以小数点表示的 x/y 点,这是物理页的第一个逻辑页中实际文本打印的开始位置。

PAGESTRING 0/1

1 表示需要在标题中的页号前附加一个“Page”字符串。

0 表示只显示页号。

EXTRAHDNGFONT font string 1 font string 2、... font string n

“font string 1”到“font string n”是 X 逻辑字体描述。将关键字 EXTRAHDNGFONT 从逗号分隔字体名称列表中分隔开的标记是 ",而不是空格或制表符。 当打印标题时,给定的首选项是这些字体,而不是内置字体。通常情况下,EXTRABODYFONT 用于分配在 /usr/openwin/server/etc/XpConfig/C/print/models/<model name>/fonts 目录中配置的打印机常驻字体。

fonts.dir 文件包含打印机常驻字体的 XLFD。

一种字体通常被指定为

 "-monotype-Gill Sans-Regular-r-normal- -*-%d-*-*-p-0-iso8859-2" 

.xpr 文件中。 "%d(如果存在的话)被 mp(1) 替换为 .xpr 文件中当前标题字体的磅值。x 分辨率和 y 分辨率由 * 指定,并且平均宽度字段设置为 0 以表示可缩放字体的选择(如果可能的话)。您也可以给出更多的特定字体名称。

EXTRABODYFONT font string 1font string 2、... font string n

EXTRAHDNGFONT 相同,除了这些字体被用来打印页面正文以外。

XDISPLACEMENT 带符号/无符号 int

给出要应用于该页的 x 坐标位移,以便在 x 方向移动该页的内容。此位移可以是 +ve 或 -ve 值。

YDISPLACEMENT signed/unsigned int

与 x 位移相同(除了移动发生在 y 方向以外)。

当您发现某些打印机具有非标准页边距宽度并且需要在页中移动打印内容时,这两个关键字很有用。

STARTPAGE/ENDPAGE

此部分中的关键字值对由 STARTPAGE ENDPAGE 关键字绑定。此部分包含要用于物理页的绘图和标题信息。物理页可包含许多逻辑页,但是,包含在这些关键字之间的所有绘图例程仅一次应用于逻辑页。

有效的绘图实体为 LINE ARCXDrawLine()XDrawArc() 函数在这些关键字的值上执行。

此部分内的尺寸被映射在 PROLOGDPI 单元中。角度以度数表示。

LINE x1 y1 x2 y2

x/y 无符号坐标定义连接一条直线的两个点。

ARC x y width height angle1 angle2

x 和 y 均为表示弧线起始点的无符号整数。width 和 height 为表示弧线的宽度和高度的无符号整数。

USERSTRINGPOS x y

无符号坐标表示标题中用户信息的打印位置。

TIMESTRINGPOS x y

无符号坐标表示标题中打印时间的打印位置。

PAGESTRINGPOS x y

无符号坐标表示每个打印页的页字符串的打印位置。

SUBJECTSTRINGPOS x y

无符号坐标表示页中主题的打印位置。

STARTFORCEDPAGE/ENDFORCEDPAGE

-n 选项分配给 mp 时,STARTPAGE/ENDPAGE 部分内的所有装饰都不打印。但是,即使给出 -n 选项,也会打印 STARTFORCEDPAGE/ENDFORCEDPAGE 部分内所包含的任何内容。

STARTCOLUMN/ENDCOLUMN

所有关键字与 STARTPAGE/ENDPAGE 中描述的相同,除了此部分中的条目可 NUMCOLS 次应用于物理页以外。

如果 NUMCOLS 为 3,则物理页的可打印区域将被分为三个部分,并且每页中直线、弧线或标题装饰将出现三次。

STARTFORCEDCOLUMN/ENDFORCEDCOLUMN

-n 选项分配给 mp 时,STARTCOLUMN/ENDCOLUMN 部分内给定的所有装饰都不打印。但是,即使给出 -n 选项,也会打印 STARTFORCEDCOLUMN/ENDFORCEDCOLUMN 部分内包含的任何内容。

创建新的 .xpr 文件

下面的值是针对不同关键字的 mp(1) 程序缺省值(如果在 STARTCOMMON/ENDCOMMON 部分的 .xpr 文件中没有指定这些值的话)。

STARTPAGE/ENDPAGE STARTCOLUMN/ENDCOLUMN 绑定的其它两个部分不需要缺省值。

当创建新的 .xpr prolog 文件时,只需要指定与缺省值不同的值。

若要创建不带装饰的页,请使用如下方式:每个物理页有四个逻辑页,打印格式为纵向格式。

在这种情况下,您不需要其它两个部分:

如果您不在打印页中加入装饰,则不需要这些参数。所有坐标的缺省值均为 300 dpi,除非您没有指定 PROLOGDPI 关键字。如果目标打印机的分辨率不同,程序将调整 .xpr 文件以适应该分辨率。

当创建 .xpr 文件时,您必须事先知道纸张的尺寸。在美国使用的纸张为 8.5x11 英寸,对于分辨率为 300 dpi 的打印机,2550X3300 为总的尺寸。大多数打印机无法从纸张的左上角打印。相反,它们在物理页周围留一定的页边距。这意味着即使您试图从 0,0 打印,也不会打印到页的左上角。当创建新的 .xpr 文件时,您需要考虑此限制。