- 主题
- 0
- 帖子
- 174
- 精华
- 1
- 积分
- 322
- C币
- 956 枚
- 在线时间
- 32 小时
- 注册时间
- 2010-2-26
- 最后登录
- 2010-11-2
- 性别
- 保密
 
- 主题
- 0
- 帖子
- 174
- C币
- 956 枚
- 在线时间
- 32 小时
|
发表于 2010-3-12 11:15:30
|显示全部楼层
2.11.3Makefile.am文件
automake处理Makefile.am,生成一个符合标准的Makefile.in文件。automake会做很多工作:例如,它维护源文件之间的依赖关系;生成所有的标准目标,比如install和clean;它还生成更复杂的目标:如果Makefile.am是正确的,简单输入 makedist就会创建一个标准的.tar.gz文件。
一般情况是在最上层目录下写一个Makefile.am,然后在每一个子目录下分别写一个Makefile.am文件。automake会从最上层开始递归处理各个Makefile.am,然后生成一个Makefile.in。在最上层目录的Makefile.am通常都很简单,下面是一个例子:
SUBDIRS=macrospointlsrcpixmapsdoc
EXTRA_DIST=\
gnome-hello.desktop
Applicationsdir=$(datadir)/gnome/apps/Applications
Applications_DATA=gnome-hello.desktop
上面程序的第一行通知automake在给定的子目录中递归查找Makefile.am文件。在src子目录的Makefile.am是这样的:
INCLUDES=-I$(top_srcdir)-I$(includedir)$(GNOME_INCLUDEDIR)\
-DG_LOG_DOMAIN=\"GnomeHello\"
-DGNOMELOCALEDIR=\""$(datadir)/locale"\"\
-I../intl-I$(top_srcdir)/intl
bin_PROGRAMS=gnome-hello
gnome_hello_SOURCES=\
app.c\
hello.c\
menus.c\
app.h\
hello.h\
menus.h
gnome_hello_LDADD=$(GNOMEUI_LIBS)$(GNOME_LIBDIR)$(INTLLIBS)
automake能够理解许多“不可思议的变量”,并用这些变量创建Makefile.in文件。在上面的小例子中,用到了下面的变量:
INCLUDES指定了在编译阶段(与连接阶段相对)中传递给C编译器的标志。这一行用到的变量来自
2.11.2节中的configure.in文件。
bin_PROGRAMS列出了要编译的程序。
hello_SOURCES列出了要编译和连接的文件,这些文件是依赖生成hello程序的。程序名必须列在bin_PROGRAMS中。在这个变量中的所有文件都被自动包含在发布包中。
hello_LDADD列出了要传递给连接程序的标志。在这个例子中是由configure决定的Gnome库标志。
INCLUDES行中有几个在所有的Gnome程序中都应该用到的元素。应该定义G_LOG_DOMAIN,来自与校验和断言代码中的错误信息会报告这个值,这样就能够判定错误是发生在什么地方(在代码中,还是在一个库中)。GNOMELOCALEDIR用于定位翻译文件。intl目录被添加到了头文件的搜索路径,这样应用程序就能够找到intl头文件。
在Makefile.am中还可以做很多复杂的事,特别是,可以添加两端带有@符号的、能带入到configure脚本中的变量。可以有条件地包含基于configure校验的Makefile文件中的一部分,还可以建立库。automake的手册介绍了细节内容。
表2-1概括了由automake生成的最常见的make目标。当然,缺省的make目标是all,它编译整个程序。GNU代码标准 (http://www.gnu.org/prep/standards_toc.html)中有这些make目标和GNUMakefile文件的详细信息。
2.11.4安装支持文件
完整的Gnome应用程序还有许多代码以外的东西。它们有在线帮助(要列在Gnome的主菜单上),有界面翻译,还有一个桌面图标。它们也许带一个pixmap以及一个用在“关于”对话框上的徽标、一个用于“向导”的图形或者一个用以帮助用户快速区别菜单项或列表元素的小图标。下面的内容介绍怎样发布这些文件。
1.安装数据文件:文档和pixmap
文档和pixmap的安装方法是差不多的。automake允许你将数据文件安装到任意位置,可以用配置文件中定义的变量决定将它们安装到哪里。
(1)pixmap
要从Makefile.am中安装数据文件,只需简单地为安装目标指定一个名字(pixmap就不错)然后为该目录和要安装到目录里的文件分别创建一个变量。例如:
EXTRA_DIST=gnome-hello-logo.png
pixmapdir=$(datadir)/pixmaps
pixmap_DATA=gnome-hello-logo.png
fill
“pixmap”字符串将pixmap_DATA变量和pixmapdir变量连接起来。automake解释_DATA前缀,并在 Makefile.in中生成适当的安装规则。这个Makefile.am片断将gnome-hello-logo.png文件安装到$(datadir)/pixmaps目录下,$(datadir)是由configure分配的变量。典型情况下,$(datadir)是/usr /local/share(更精确的说,是$(prefix)/share),这是独立于体系结构的数据文件(也就是,几个具有不同二进制文件格式的系统共享的文件)的标准位置。
Gnome的pixmap图片的标准位置是$(datadir)/pixmaps,所以在例子中我们这样用。Gnome项目鼓励在所有的 pixmap图片中使用PNG格式,这个格式是gdk_imlib(Gnome图象加载库)支持的。它的文件尺寸小,速度快,也不存在专利问题。
(2)文档
安装文档使用同样的原则,不过稍有一点复杂。Gnome文档通常是用DocBook写的。DocBook是一个 SGMLDTD(DocumentTypeDefinition,文档类型定义),就像HTML一样。然而,DocBook的文档标签是为技术文档设计的。用DocBook写的文档可以转换为其他格式,包括PostScript和HTML。依照标准,应该安装HTML格式的文档,用户就可以用Web浏览器或Gnome帮助浏览器阅读文档。
Gnome库和帮助浏览器能理解一个名为topic.dat的文件,这个文件只是一个含有相应URL的帮助主题列表。它起应用程序帮助主题索引的作用。下面是一个例子,只有两条:
gnome-hello.htmlGnomeHellomanual
advanced.htmlAdvancedTopics
URL路径相对于所安装的帮助文件的目录。
应该预先考虑文档可能会翻译为其他语言。最好为每一个地区建立一个子目录,例如,缺省地区(C)或es(西班牙语)。使用这种方法翻译程序不会引起混乱。一般将Gnome帮助安装在以地区开头的目录下,这种做法用其他观点来看也是很方便的。文档目录看起来也许和GnomeHello示例程序差不多:
doc/
Makefile.am
C/
Makefile.am
gnome-hello.sgml
topic.dat
es/
Makefile.am
gnome-hello.sgml
topic.dat
下面是doc/C/Makefile.am:
gnome_hello_helpdir=$(datadir)/gnome/help/gnome-hello/C
gnome_hello_help_DATA=\
gnome-hello.html\
topic.dat
SGML_FILES=\
gnome-hello.sgml
#filesthataren’tinabinary/data/librarytargethavetobelistedhere
#tobeincludedinthetarballwhenyou‘makedist’
EXTRA_DIST=\
topic.dat\
$(SGML_FILES)
##The-beforethecommandmeanstoignoreitifitfails.Thatway
##peoplecanstillbuildthesoftwarewithoutthedocbooktools
all:
gnome-hello.html:gnome-hello/gnome-hello.html
-cpgnome-hello/gnome-hello.html.
gnome-hello/gnome-hello.html (SGML_FILES)
-db2htmlgnome-hello.sgml
##whenwemakedist,weincludethegeneratedHTMLsopeopledon’t
##havetohavethedocbooktools
dist-hook:
mkdir$(distdir)/gnome-hello
-cpgnome-hello/*.htmlgnome-hello/*.css$(distdir)/gnome-hello
-cpgnome-hello.html$(distdir)
install-data-local:gnome-hello.html
$(mkinstalldirs)$(gnome_hello_helpdir)/images
-forfilein$(srcdir)/gnome-hello/*.html$(srcdir)/gnome-hello/*.css;do\
basefile=`basename$$file`;\
$(INSTALL_DATA)$(srcdir)/$$file$(gnome_hello_helpdir)/$$basefile;\
done
gnome-hello.ps:gnome-hello.sgml
-db2ps$<
gnome-hello.rtf:gnome-hello.sgml
-db2rtf$<
需要特别注意的是生成的HTML文件的安装目录:$(datadir)/gnome/help/gnome-hello/C。Gnome库在这里查找帮助文件。每个应用程序的帮助都放在$(datadir)/gnome/help下的它自己的目录下。每个地区的文档都安装在应用程序目录的对应于地区的子目录下。
2..desktop入口
Gnome程序带有一个.desktop入口,它是一个以desktop为后缀的文本文件,描述应用程序应该放在Gnome主菜单的什么位置。安装一个.desktop入口文件可以让应用程序显示在Gnome面板菜单(主菜单)中。下面是gnome-hello.desktop文件:
[DesktopEntry]
Name=GnomeHello
Name[es]=GnomeHola
Name[fi]=GNOME-hei
Name[no]=Gnomehallo
Name[sv]=GnomeHej
Comment=HelloWorld
Comment[es]=HolaMundo
Comment[fi]=Hei,maailma
Comment[sv]=HejV?rlden
Comment[no]=Halloverden
Exec=gnome-hello
Icon=gnome-hello-logo.png
Terminal=0
Type=Application
这个文件由键-值对组成。Name键指定在缺省地区场合的名称;任何键都可以有一个用于标明地区的字符串,放在一对方括号里面。当登录到X窗口时,如果指定了不同的地区,系统会根据语言从这里读取相应的字符串。Comment键是一个“工具提示”或“暗示”,用以更详细地描述应用程序。Exec 是用来执行程序的命令行。Terminal是布尔类型,如果为非0值,程序在一个终端内运行。在这里Type应该是“Application”
安装一个.desktop条目很简单。下面是GnomeHello中的最顶层的Makefile.am文件:
SUBDIRS=macrospointlsrcpixmapsdoc
EXTRA_DIST=\
gnome-hello.desktop
Applicationsdir=$(datadir)/gnome/apps/Applications
Applications_DATA=gnome-hello.desktop
注意,在$(datadir)/gnome/apps/下有一个目录树,可以将应用程序安装到下面子目录所对应的类别中。GnomeHello 将自己安装在“Applications”类中,而其他的应用程序也许会选择Games、Graphics、Internet或者其他合适的地方。尽量选择一个已经存在的类别,而不是自己建一个。
Makefile.am中的EXTRA_DIST变量列出了需要包含在发布软件包(压缩的tar文件)中的文件。最重要的文件会自动包含进来,例如,所有作为二进制或库的源文件的文件都会自动包含。
然而,automake并不认识.desktop文件,或SGML文档,所有这些文件必须列在EXTRA_DIST中。如果将这些文件留在EXTRA_DIST之外,用makedistcheck命令编译发布程序通常会失败。 |
|