1 ## Process this file with automake to produce Makefile.in
3 # The name of the module.
6 # The top-level SGML file.
7 DOC_MAIN_SGML_FILE=gtk-docs.sgml
9 # The directory containing the source code. Relative to $(srcdir)
10 DOC_SOURCE_DIR=../../../gtk
12 # Extra options to pass to gtkdoc-scangobj
13 SCANGOBJ_OPTIONS=--type-init-func="gtk_type_init(0)"
15 # Extra options to supply to gtkdoc-scan
16 SCAN_OPTIONS=--deprecated-guards="GTK_ENABLE_BROKEN|GTK_DISABLE_DEPRECATED"
18 # Extra options to supply to gtkdoc-mkdb
19 MKDB_OPTIONS=--sgml-mode
21 # Extra options to supply to gtkdoc-fixref
22 FIXXREF_OPTIONS=--extra-dir=../gdk-pixbuf/html --extra-dir=../gdk/html
24 # Used for dependencies
25 HFILE_GLOB=$(top_srcdir)/gtk/*.h
26 CFILE_GLOB=$(top_srcdir)/gtk/*.c
28 # Header files to ignore when scanning
44 gtktextiterprivate.h \
46 gtktextmarkprivate.h \
54 # Images to copy into HTML directory
56 $(top_srcdir)/gtk/stock-icons/stock_add_24.png \
57 $(top_srcdir)/gtk/stock-icons/stock_apply_20.png \
58 $(top_srcdir)/gtk/stock-icons/stock_text_bold_24.png \
59 $(top_srcdir)/gtk/stock-icons/stock_cancel_20.png \
60 $(top_srcdir)/gtk/stock-icons/stock_cdrom_24.png \
61 $(top_srcdir)/gtk/stock-icons/stock_clear_24.png \
62 $(top_srcdir)/gtk/stock-icons/stock_close_24.png \
63 $(top_srcdir)/gtk/stock-icons/stock_convert_24.png \
64 $(top_srcdir)/gtk/stock-icons/stock_copy_24.png \
65 $(top_srcdir)/gtk/stock-icons/stock_cut_24.png \
66 $(top_srcdir)/gtk/stock-icons/stock_trash_24.png \
67 $(top_srcdir)/gtk/stock-icons/stock_dialog_error_48.png \
68 $(top_srcdir)/gtk/stock-icons/stock_dialog_info_48.png \
69 $(top_srcdir)/gtk/stock-icons/stock_dialog_question_48.png \
70 $(top_srcdir)/gtk/stock-icons/stock_dialog_warning_48.png \
71 $(top_srcdir)/gtk/stock-icons/stock_dnd_32.png \
72 $(top_srcdir)/gtk/stock-icons/stock_dnd_multiple_32.png \
73 $(top_srcdir)/gtk/stock-icons/stock_exec_24.png \
74 $(top_srcdir)/gtk/stock-icons/stock_search_24.png \
75 $(top_srcdir)/gtk/stock-icons/stock_search_replace_24.png \
76 $(top_srcdir)/gtk/stock-icons/stock_save_24.png \
77 $(top_srcdir)/gtk/stock-icons/stock_bottom_24.png \
78 $(top_srcdir)/gtk/stock-icons/stock_first_24.png \
79 $(top_srcdir)/gtk/stock-icons/stock_last_24.png \
80 $(top_srcdir)/gtk/stock-icons/stock_top_24.png \
81 $(top_srcdir)/gtk/stock-icons/stock_left_arrow_24.png \
82 $(top_srcdir)/gtk/stock-icons/stock_down_arrow_24.png \
83 $(top_srcdir)/gtk/stock-icons/stock_right_arrow_24.png \
84 $(top_srcdir)/gtk/stock-icons/stock_up_arrow_24.png \
85 $(top_srcdir)/gtk/stock-icons/stock_help_24.png \
86 $(top_srcdir)/gtk/stock-icons/stock_home_24.png \
87 $(top_srcdir)/gtk/stock-icons/stock_index_24.png \
88 $(top_srcdir)/gtk/stock-icons/stock_text_italic_24.png \
89 $(top_srcdir)/gtk/stock-icons/stock_jump_to_24.png \
90 $(top_srcdir)/gtk/stock-icons/stock_align_center_24.png \
91 $(top_srcdir)/gtk/stock-icons/stock_align_justify_24.png \
92 $(top_srcdir)/gtk/stock-icons/stock_align_left_24.png \
93 $(top_srcdir)/gtk/stock-icons/stock_align_right_24.png \
94 $(top_srcdir)/gtk/stock-icons/stock_new_24.png \
95 $(top_srcdir)/gtk/stock-icons/stock_no_20.png \
96 $(top_srcdir)/gtk/stock-icons/stock_ok_20.png \
97 $(top_srcdir)/gtk/stock-icons/stock_open_24.png \
98 $(top_srcdir)/gtk/stock-icons/stock_paste_24.png \
99 $(top_srcdir)/gtk/stock-icons/stock_preferences_24.png \
100 $(top_srcdir)/gtk/stock-icons/stock_print_24.png \
101 $(top_srcdir)/gtk/stock-icons/stock_print_preview_24.png \
102 $(top_srcdir)/gtk/stock-icons/stock_properties_24.png \
103 $(top_srcdir)/gtk/stock-icons/stock_exit_24.png \
104 $(top_srcdir)/gtk/stock-icons/stock_redo_24.png \
105 $(top_srcdir)/gtk/stock-icons/stock_refresh_24.png \
106 $(top_srcdir)/gtk/stock-icons/stock_remove_24.png \
107 $(top_srcdir)/gtk/stock-icons/stock_revert_24.png \
108 $(top_srcdir)/gtk/stock-icons/stock_save_24.png \
109 $(top_srcdir)/gtk/stock-icons/stock_save_as_24.png \
110 $(top_srcdir)/gtk/stock-icons/stock_colorselector_24.png \
111 $(top_srcdir)/gtk/stock-icons/stock_font_24.png \
112 $(top_srcdir)/gtk/stock-icons/stock_sort_ascending_24.png \
113 $(top_srcdir)/gtk/stock-icons/stock_sort_descending_24.png \
114 $(top_srcdir)/gtk/stock-icons/stock_spellcheck_24.png \
115 $(top_srcdir)/gtk/stock-icons/stock_stop_24.png \
116 $(top_srcdir)/gtk/stock-icons/stock_text_strikethrough_24.png \
117 $(top_srcdir)/gtk/stock-icons/stock_undelete_24.png \
118 $(top_srcdir)/gtk/stock-icons/stock_text_underline_24.png \
119 $(top_srcdir)/gtk/stock-icons/stock_undo_24.png \
120 $(top_srcdir)/gtk/stock-icons/stock_yes_20.png \
121 $(top_srcdir)/gtk/stock-icons/stock_zoom_1_24.png \
122 $(top_srcdir)/gtk/stock-icons/stock_zoom_fit_24.png \
123 $(top_srcdir)/gtk/stock-icons/stock_zoom_in_24.png \
124 $(top_srcdir)/gtk/stock-icons/stock_zoom_out_24.png
126 # Extra SGML files that are included by $(DOC_MAIN_SGML_FILE)
134 objects_grouped.sgml \
135 question_index.sgml \
142 # Other files to distribute
145 # CFLAGS and LDFLAGS for compiling scan program. Only needed
146 # if $(DOC_MODULE).types is non-empty.
147 GTKDOC_CFLAGS = @STRIP_BEGIN@ \
151 -I$(top_builddir)/gdk \
152 -DGTK_ENABLE_BROKEN \
157 GTKDOC_LIBS = @STRIP_BEGIN@ \
158 $(top_builddir)/gdk-pixbuf/libgdk_pixbuf-1.3.la \
159 $(top_builddir)/gdk/@gdktargetlib@ \
160 $(top_builddir)/gtk/@gtktargetlib@ \
163 GTKDOC_CC=$(LIBTOOL) --mode=compile $(CC)
164 GTKDOC_LD=$(LIBTOOL) --mode=link $(CC)
167 ####################################
168 # Everything below here is generic #
169 ####################################
171 # We set GPATH here; this gives us semantics for GNU make
172 # which are more like other make's VPATH, when it comes to
173 # whether a source that is a target of one rule is then
174 # searched for in VPATH/GPATH.
178 TARGET_DIR=$(HTML_DIR)/$(DOC_MODULE)
184 $(DOC_MAIN_SGML_FILE) \
185 $(DOC_MODULE).types \
186 $(DOC_MODULE)-sections.txt \
187 $(DOC_MODULE)-overrides.txt
189 DOC_STAMPS=scan-build.stamp tmpl-build.stamp sgml-build.stamp html-build.stamp \
190 $(srcdir)/tmpl.stamp $(srcdir)/sgml.stamp $(srcdir)/html.stamp
194 $(DOC_MODULE).hierarchy \
195 $(DOC_MODULE).signals
198 all-local: html-build.stamp
202 scan-build.stamp: $(HFILE_GLOB)
203 @echo '*** Scanning header files ***'
204 if grep -l '^..*$$' $(srcdir)/$(DOC_MODULE).types > /dev/null ; then \
205 CC="$(GTKDOC_CC)" LD="$(GTKDOC_LD)" CFLAGS="$(GTKDOC_CFLAGS)" LDFLAGS="$(GTKDOC_LIBS)" gtkdoc-scangobj $(SCANGOBJ_OPTIONS) --module=$(DOC_MODULE) --output-dir=$(srcdir) ; \
208 for i in $(SCANOBJ_FILES) ; do \
209 test -f $$i || touch $$i ; \
213 gtkdoc-scan --module=$(DOC_MODULE) --source-dir=$(DOC_SOURCE_DIR) --ignore-headers="$(IGNORE_HFILES)" $(SCAN_OPTIONS) $(EXTRA_HFILES)
214 touch scan-build.stamp
216 $(DOC_MODULE)-decl.txt $(SCANOBJ_FILES): scan-build.stamp
221 tmpl-build.stamp: $(DOC_MODULE)-decl.txt $(SCANOBJ_FILES) $(DOC_MODULE)-sections.txt $(DOC_MODULE)-overrides.txt
222 @echo '*** Rebuilding template files ***'
223 cd $(srcdir) && gtkdoc-mktmpl --module=$(DOC_MODULE)
224 touch tmpl-build.stamp
226 tmpl.stamp: tmpl-build.stamp
231 sgml-build.stamp: tmpl.stamp $(CFILE_GLOB) $(srcdir)/tmpl/*.sgml
232 @echo '*** Building SGML ***'
234 gtkdoc-mkdb --module=$(DOC_MODULE) --source-dir=$(DOC_SOURCE_DIR) $(MKDB_OPTIONS)
235 touch sgml-build.stamp
237 sgml.stamp: sgml-build.stamp
242 html-build.stamp: sgml.stamp $(DOC_MAIN_SGML_FILE) $(content_files)
243 @echo '*** Building HTML ***'
244 rm -rf $(srcdir)/html
246 cd $(srcdir)/html && gtkdoc-mkhtml $(DOC_MODULE) ../$(DOC_MAIN_SGML_FILE)
247 test "x$(HTML_IMAGES)" = "x" || ( cd $(srcdir) && cp $(HTML_IMAGES) html )
248 @echo '-- Fixing Crossreferences'
249 cd $(srcdir) && gtkdoc-fixxref --module-dir=html --html-dir=$(HTML_DIR) $(FIXXREF_OPTIONS)
250 touch html-build.stamp
256 rm -f *~ *.bak $(SCANOBJ_FILES) *-unused.txt $(DOC_STAMPS)
258 maintainer-clean-local: clean
259 cd $(srcdir) && rm -rf sgml html $(DOC_MODULE)-decl-list.txt $(DOC_MODULE)-decl.txt
262 $(mkinstalldirs) $(DESTDIR)$(TARGET_DIR)
263 (installfiles=`echo $(srcdir)/html/*`; \
264 if test "$$installfiles" = '$(srcdir)/html/*'; \
265 then echo '-- Nothing to install' ; \
267 for i in $$installfiles; do \
268 echo '-- Installing '$$i ; \
269 $(INSTALL_DATA) $$i $(DESTDIR)$(TARGET_DIR); \
271 echo '-- Installing $(srcdir)/html/index.sgml' ; \
272 $(INSTALL_DATA) $(srcdir)/html/index.sgml $(DESTDIR)$(TARGET_DIR); \
276 # Require gtk-doc when making dist
282 @echo "*** gtk-doc must be installed and enabled in order to make dist"
286 dist-hook: dist-check-gtkdoc dist-hook-local
287 mkdir $(distdir)/tmpl
288 mkdir $(distdir)/sgml
289 mkdir $(distdir)/html
290 -cp $(srcdir)/tmpl/*.sgml $(distdir)/tmpl
291 -cp $(srcdir)/sgml/*.sgml $(distdir)/sgml
292 -cp $(srcdir)/html/* $(distdir)/html
294 .PHONY : dist-hook-local