Documentation updates. All standard library objects and standard elements are documen...
[platform/upstream/gstreamer.git] / docs / gst / Makefile.am
1 ## Process this file with automake to produce Makefile.in
2
3 # The name of the module.
4 DOC_MODULE=gstreamer
5
6 # The top-level SGML file.
7 DOC_MAIN_SGML_FILE=gstreamer-docs.sgml
8
9 # The directory containing the source code (if it contains documentation).
10 DOC_SOURCE_DIR=$(top_srcdir)/gst
11
12 CFLAGS = $(GLIB_CFLAGS) $(GTK_CFLAGS) -I$(top_srcdir)
13 LDFLAGS = $(GLIB_LIBS) $(GTK_LIBS) $(top_srcdir)/gst/libgst.la $(top_srcdir)/gst/elements/libgstelements.la
14
15 HTML_DIR=$(datadir)/gstreamer/gst/html
16
17 TARGET_DIR=$(HTML_DIR)/$(DOC_MODULE)
18
19 tmpl_sources =                          \
20         tmpl/audioraw.sgml              \
21         tmpl/cothreads.sgml             \
22         tmpl/gst.sgml                   \
23         tmpl/gstasyncdisksrc.sgml       \
24         tmpl/gstaudiosink.sgml          \
25         tmpl/gstaudiosrc.sgml           \
26         tmpl/gstbin.sgml                \
27         tmpl/gstbuffer.sgml             \
28         tmpl/gstconnection.sgml         \
29         tmpl/gstdisksrc.sgml            \
30         tmpl/gstelement.sgml            \
31         tmpl/gstesdsink.sgml            \
32         tmpl/gstfakesink.sgml           \
33         tmpl/gstfakesrc.sgml            \
34         tmpl/gstfdsink.sgml             \
35         tmpl/gstfdsrc.sgml              \
36         tmpl/gstfilter.sgml             \
37         tmpl/gsthttpsrc.sgml            \
38         tmpl/gstidentity.sgml           \
39         tmpl/gstlog.sgml                \
40         tmpl/gstmeta.sgml               \
41         tmpl/gstobject.sgml             \
42         tmpl/gstpad.sgml                \
43         tmpl/gstpipeline.sgml           \
44         tmpl/gstplugin.sgml             \
45         tmpl/gstqueue.sgml              \
46         tmpl/gstreamer-unused.sgml      \
47         tmpl/gstsinesrc.sgml            \
48         tmpl/gstsink.sgml               \
49         tmpl/gstsrc.sgml                \
50         tmpl/gsttee.sgml                \
51         tmpl/gstthread.sgml             \
52         tmpl/gsttrace.sgml              \
53         tmpl/gsttype.sgml               \
54         tmpl/gstutils.sgml              \
55         tmpl/gstxml.sgml                \
56         tmpl/spectrum.sgml              \
57         tmpl/videoraw.sgml
58
59 gstreamer_docdir = $(HTML_DIR)
60 gstreamer_doc_DATA =            \
61         gstreamer.html          \
62         gstreamer.hierarchy     \
63         gstreamer.types         \
64         gstreamer-decl.txt      \
65         gstreamer-sections.txt
66
67 SCANOBJS_FILES =                \
68         $(DOC_MODULE).signals   \
69         $(DOC_MODULE).hierarchy \
70         $(DOC_MODULE).args
71
72 if HAVE_GTK_DOC
73 gstreamer.html: html/book1.html
74         -cd $(srcdir) && cp html/book1.html gstreamer.html
75 else
76 gstreamer.html:
77 endif
78
79 html/book1.html: sgml/gstreamer-doc.bottom
80         $(MAKE) html
81
82 sgml/gstreamer-doc.bottom: $(tmpl_sources)
83         $(MAKE) sgml
84
85 gstreamer-decl.txt:
86         $(MAKE) scan
87
88 scanobj:
89         env CC="$(LIBTOOL) --mode=link $(CC)" CFLAGS="$(CFLAGS)" LDFLAGS="$(LDFLAGS)" \
90                 gtkdoc-scanobj --module=$(DOC_MODULE) \
91                 --types=$(srcdir)/$(DOC_MODULE).types
92
93 scan:
94         gtkdoc-scan --module=$(DOC_MODULE) --source-dir=$(DOC_SOURCE_DIR) --ignore-headers="gsttypefind.h"
95
96 tmpl: scanobj scan
97         gtkdoc-mktmpl --module=$(DOC_MODULE)
98
99 sgml: tmpl
100         gtkdoc-mkdb --module=$(DOC_MODULE) --source-dir=$(DOC_SOURCE_DIR)
101
102 html:
103         if ! test -d html ; then mkdir html ; fi
104         -cd html && gtkdoc-mkhtml $(DOC_MODULE) ../$(DOC_MAIN_SGML_FILE)
105
106 clean-local:
107         rm -f *~ *.bak *.signals *-unused.txt *.args
108
109 maintainer-clean-local: clean
110         rm -rf sgml html $(DOC_MODULE)-decl-list.txt $(DOC_MODULE)-decl.txt 
111
112 install-data-local:
113         $(mkinstalldirs) $(DESTDIR)$(TARGET_DIR)
114         (installfiles=`echo $(srcdir)/html/*.html`; \
115         if test "$$installfiles" = '$(srcdir)/html/*.html'; \
116         then echo '-- Nothing to install' ; \
117         else \
118           for i in $$installfiles; do \
119             echo '-- Installing '$$i ; \
120             $(INSTALL_DATA) $$i $(DESTDIR)$(TARGET_DIR); \
121           done; \
122           echo '-- Installing $(srcdir)/html/index.sgml' ; \
123           $(INSTALL_DATA) $(srcdir)/html/index.sgml $(DESTDIR)$(TARGET_DIR); \
124           echo '-- Fixing Crossreferences' ; \
125           gtkdoc-fixxref --module=$(DOC_MODULE) --html-dir=$(HTML_DIR)|| true; \
126         fi)
127
128 dist-hook:
129         mkdir $(distdir)/html
130         mkdir $(distdir)/sgml
131         mkdir $(distdir)/tmpl
132         -cp $(srcdir)/html/*.html $(srcdir)/html/*.css $(distdir)/html
133         -cp $(srcdir)/tmpl/*.sgml $(distdir)/tmpl
134         -cp $(srcdir)/sgml/*.sgml $(distdir)/sgml
135         -cp $(srcdir)/sgml/*.bottom $(srcdir)/sgml/*.top $(distdir)/sgml
136
137 .PHONY : html sgml templates scan