diff options
author | cpk <cpk> | 2001-10-13 00:08:39 +0000 |
---|---|---|
committer | cpk <cpk@7cbeb6ba-43b4-40fd-8cce-4c39aea84d33> | 2001-10-13 00:08:39 +0000 |
commit | 6c52152328afcfcc324d84af18b509ce4cddf4a9 (patch) | |
tree | eb5af635f8e37ab5dc5d0510a3b89f355cf53bbb /doc | |
parent | a41a7d88753304d4458aeb3d4635e54c5b51703e (diff) | |
download | enlightenment-6c52152328afcfcc324d84af18b509ce4cddf4a9.tar.gz enlightenment-6c52152328afcfcc324d84af18b509ce4cddf4a9.tar.xz enlightenment-6c52152328afcfcc324d84af18b509ce4cddf4a9.zip |
Documentation setup ...
SVN revision: 5479
Diffstat (limited to 'doc')
-rw-r--r-- | doc/Makefile.am | 46 | ||||
-rw-r--r-- | doc/figures/background.gif | bin | 0 -> 6432 bytes | |||
-rw-r--r-- | doc/figures/caution.gif | bin | 0 -> 1039 bytes | |||
-rw-r--r-- | doc/figures/note.gif | bin | 0 -> 1070 bytes | |||
-rw-r--r-- | doc/figures/warning.gif | bin | 0 -> 1052 bytes | |||
-rw-r--r-- | doc/html-customizations.dsl.in | 61 | ||||
-rw-r--r-- | doc/kernel-doc.in | 1001 | ||||
-rw-r--r-- | doc/manual.raw | 283 | ||||
-rw-r--r-- | doc/stylesheet.css | 20 |
9 files changed, 1411 insertions, 0 deletions
diff --git a/doc/Makefile.am b/doc/Makefile.am new file mode 100644 index 000000000..45b163779 --- /dev/null +++ b/doc/Makefile.am @@ -0,0 +1,46 @@ +## Process this file with automake to produce Makefile.in + +MAINTAINERCLEANFILES = Makefile.in + +EXTRA_DIST = \ +manual.raw \ +kernel-doc.in \ +stylesheet.css \ +figures/*.gif # Add any images you create here + + +## Fill in all source files that you documented +## with extractable comments here: +## +SOURCEDOC = $(top_srcdir)/src/e.h + +## For details on what can be specified in the +## comments, see the beginning of kernel-doc +## in this directory! -- cK. + + +SGMLFILE = $(PACKAGE)-manual.sgml + +docs: manual.raw $(SOURCEDOC) + ./kernel-doc -docbook <manual.raw >$(SGMLFILE) + +if HAVE_JADE + +FULLNAME = $(PACKAGE)-manual-$(VERSION) + +html-docs: docs html-customizations.dsl + $(mkinstalldirs) ./$(FULLNAME)/figures + cd $(FULLNAME) && @JADE@ -t sgml -d ../html-customizations.dsl ../$(SGMLFILE) + - cd figures && cp -f *.gif ../$(FULLNAME)/figures + - cd figures && cp -f *.png ../$(FULLNAME)/figures + - cd figures && cp -f *.jpg ../$(FULLNAME)/figures + cp -f stylesheet.css $(FULLNAME)/stylesheet.css + tar cfvz $(FULLNAME).tar.gz $(FULLNAME) + +html-filetypes: filetypes.xsl + $(mkinstalldirs) ./$(FULLNAME)/filetypes + cp -fr filetypes-templates/* ./$(FULLNAME)/filetypes + ./generate-trees.sh ./$(FULLNAME)/filetypes + +endif + diff --git a/doc/figures/background.gif b/doc/figures/background.gif Binary files differnew file mode 100644 index 000000000..1dc11ce83 --- /dev/null +++ b/doc/figures/background.gif diff --git a/doc/figures/caution.gif b/doc/figures/caution.gif Binary files differnew file mode 100644 index 000000000..542232911 --- /dev/null +++ b/doc/figures/caution.gif diff --git a/doc/figures/note.gif b/doc/figures/note.gif Binary files differnew file mode 100644 index 000000000..45fe08649 --- /dev/null +++ b/doc/figures/note.gif diff --git a/doc/figures/warning.gif b/doc/figures/warning.gif Binary files differnew file mode 100644 index 000000000..9c1104c2b --- /dev/null +++ b/doc/figures/warning.gif diff --git a/doc/html-customizations.dsl.in b/doc/html-customizations.dsl.in new file mode 100644 index 000000000..4bf0404d0 --- /dev/null +++ b/doc/html-customizations.dsl.in @@ -0,0 +1,61 @@ +<!DOCTYPE style-sheet PUBLIC "-//James Clark//DTD DSSSL Style Sheet//EN" [ +<!ENTITY dbstyle SYSTEM "@DB_STYLESHEETS@/html/docbook.dsl" CDATA DSSSL> +]> + +<style-sheet> +<style-specification use="docbook"> +<style-specification-body> + +;; my own customizations for HTML output: + +(define %admon-graphics-path% + ;; Path to admonition graphics + "figures/") + +(define %admon-graphics% + ;; Use graphics in admonitions? + #t) + +(define %indent-programlisting-lines% + ;; Indent lines in a 'ProgramListing'? + " ") + +(define %shade-verbatim% + ;; Should verbatim environments be shaded? + #t) + +(define ($shade-verbatim-attr$) + ;; Attributes used to create a shaded verbatim environment. + (list + (list "BORDER" "0") + (list "BGCOLOR" "#f0f0f0"))) + +(define %root-filename% + ;; Name for the root HTML document + "index") + +(define %body-attr% + ;; What attributes should be hung off of BODY? + (list + (list "BGCOLOR" "#FFFFFF") + (list "TEXT" "#0000A0") + (list "LINK" "#2020D0") + (list "VLINK" "#000060") + (list "ALINK" "#5050F0"))) + +(define %css-decoration% + ;; Enable CSS decoration of elements + #t) + +(define %stylesheet% + ;; Name of the stylesheet to use + "stylesheet.css") + +(define biblio-number + ;; Enumerate bibliography entries + #t) + +</style-specification-body> +</style-specification> +<external-specification id="docbook" document="dbstyle"> +</style-sheet> diff --git a/doc/kernel-doc.in b/doc/kernel-doc.in new file mode 100644 index 000000000..4865a89bd --- /dev/null +++ b/doc/kernel-doc.in @@ -0,0 +1,1001 @@ +#!@PERL@ + +## This script is based on the script shipped with ## +## 2.4 Linux kernel sources. All copyright notices etc ## +## remain unchanged. --cK. ## + +## Copyright (c) 1998 Michael Zucchi, All Rights Reserved ## +## Copyright (C) 2000 Tim Waugh <twaugh@redhat.com> ## +## ## +## #define enhancements by Armin Kuster <akuster@mvista.com> ## +## Copyright (c) 2000 MontaVista Software, Inc. ## +## ## +## This software falls under the GNU General Public License. ## +## Please read the COPYING file for more information ## + +# w.o. 03-11-2000: added the '-filelist' option. + +# +# This will read a 'c' file and scan for embedded comments in the +# style of gnome comments (+minor extensions - see below). +# + +# Note: This only supports 'c'. + +# usage: +# kerneldoc [ -docbook | -html | -text | -man ] +# [ -function funcname [ -function funcname ...] ] c file(s)s > outputfile +# or +# [ -nofunction funcname [ -function funcname ...] ] c file(s)s > outputfile +# +# Set output format using one of -docbook -html -text or -man. Default is man. +# +# -function funcname +# If set, then only generate documentation for the given function(s). All +# other functions are ignored. +# +# -nofunction funcname +# If set, then only generate documentation for the other function(s). All +# other functions are ignored. Cannot be used with -function together +# (yes thats a bug - perl hackers can fix it 8)) +# +# c files - list of 'c' files to process +# +# All output goes to stdout, with errors to stderr. + +# +# format of comments. +# In the following table, (...)? signifies optional structure. +# (...)* signifies 0 or more structure elements +# /** +# * function_name(:)? (- short description)? +# (* @parameterx: (description of parameter x)?)* +# (* a blank line)? +# * (Description:)? (Description of function)? +# * (section header: (section description)? )* +# (*)?*/ +# +# So .. the trivial example would be: +# +# /** +# * my_function +# **/ +# +# If the Description: header tag is ommitted, then there must be a blank line +# after the last parameter specification. +# e.g. +# /** +# * my_function - does my stuff +# * @my_arg: its mine damnit +# * +# * Does my stuff explained. +# */ +# +# or, could also use: +# /** +# * my_function - does my stuff +# * @my_arg: its mine damnit +# * Description: Does my stuff explained. +# */ +# etc. +# +# All descriptions can be multiline, apart from the short function description. +# +# All descriptive text is further processed, scanning for the following special +# patterns, which are highlighted appropriately. +# +# 'funcname()' - function +# '$ENVVAR' - environmental variable +# '&struct_name' - name of a structure (up to two words including 'struct') +# '@parameter' - name of a parameter +# '%CONST' - name of a constant. + +# match expressions used to find embedded type information +$type_constant = "\\\%([-_\\w]+)"; +$type_func = "(\\w+)\\(\\)"; +$type_param = "\\\@(\\w+)"; +$type_struct = "\\\&((struct\\s*)?[_\\w]+)"; +$type_env = "(\\\$\\w+)"; + + +# Output conversion substitutions. +# One for each output format + +# these work fairly well +%highlights_html = ( $type_constant, "<i>\$1</i>", + $type_func, "<b>\$1</b>", + $type_struct, "<i>\$1</i>", + $type_param, "<tt><b>\$1</b></tt>" ); +$blankline_html = "<p>"; + +# sgml, docbook format +%highlights_sgml = ( "([^=])\\\"([^\\\"<]+)\\\"", "\$1<quote>\$2</quote>", + $type_constant, "<constant>\$1</constant>", + $type_func, "<function>\$1</function>", + $type_struct, "<structname>\$1</structname>", + $type_env, "<envar>\$1</envar>", + $type_param, "<parameter>\$1</parameter>" ); +$blankline_sgml = "</para><para>\n"; + +# gnome, docbook format +%highlights_gnome = ( $type_constant, "<replaceable class=\"option\">\$1</replaceable>", + $type_func, "<function>\$1</function>", + $type_struct, "<structname>\$1</structname>", + $type_env, "<envar>\$1</envar>", + $type_param, "<parameter>\$1</parameter>" ); +$blankline_gnome = "</para><para>\n"; + +# these are pretty rough +%highlights_man = ( $type_constant, "\$1", + $type_func, "\\\\fB\$1\\\\fP", + $type_struct, "\\\\fI\$1\\\\fP", + $type_param, "\\\\fI\$1\\\\fP" ); +$blankline_man = ""; + +# text-mode +%highlights_text = ( $type_constant, "\$1", + $type_func, "\$1", + $type_struct, "\$1", + $type_param, "\$1" ); +$blankline_text = ""; + + +sub usage { + print "Usage: $0 [ -v ] [ -docbook | -html | -text | -man ]\n"; + print " [ -function funcname [ -function funcname ...] ]\n"; + print " [ -nofunction funcname [ -nofunction funcname ...] ]\n"; + print " < inputfile > outputfile\n"; + exit 1; +} + +# read arguments +if ($#ARGV==-1) { + usage(); +} + +$verbose = 0; +$output_mode = "man"; +%highlights = %highlights_man; +$blankline = $blankline_man; +$modulename = "API Documentation"; +$function_only = 0; +$filelist = ''; + +while ($ARGV[0] =~ m/^-(.*)/) { + $cmd = shift @ARGV; + if ($cmd eq "-html") { + $output_mode = "html"; + %highlights = %highlights_html; + $blankline = $blankline_html; + } elsif ($cmd eq "-man") { + $output_mode = "man"; + %highlights = %highlights_man; + $blankline = $blankline_man; + } elsif ($cmd eq "-text") { + $output_mode = "text"; + %highlights = %highlights_text; + $blankline = $blankline_text; + } elsif ($cmd eq "-docbook") { + $output_mode = "sgml"; + %highlights = %highlights_sgml; + $blankline = $blankline_sgml; + } elsif ($cmd eq "-gnome") { + $output_mode = "gnome"; + %highlights = %highlights_gnome; + $blankline = $blankline_gnome; + } elsif ($cmd eq "-module") { # not needed for sgml, inherits from calling document + $modulename = shift @ARGV; + } elsif ($cmd eq "-function") { # to only output specific functions + $function_only = 1; + $function = shift @ARGV; + $function_table{$function} = 1; + } elsif ($cmd eq "-nofunction") { # to only output specific functions + $function_only = 2; + $function = shift @ARGV; + $function_table{$function} = 1; + } elsif ($cmd eq "-v") { + $verbose = 1; + } elsif (($cmd eq "-h") || ($cmd eq "--help")) { + usage(); + } +} + + +# generate a sequence of code that will splice in highlighting information +# using the s// operator. +$dohighlight = ""; +foreach $pattern (keys %highlights) { +# print "scanning pattern $pattern ($highlights{$pattern})\n"; + $dohighlight .= "\$contents =~ s:$pattern:$highlights{$pattern}:gs;\n"; +} + +## +# dumps section contents to arrays/hashes intended for that purpose. +# +sub dump_section { + my $name = shift @_; + my $contents = join "\n", @_; + + if ($name =~ m/$type_constant/) { + $name = $1; +# print STDERR "constant section '$1' = '$contents'\n"; + $constants{$name} = $contents; + } elsif ($name =~ m/$type_param/) { +# print STDERR "parameter def '$1' = '$contents'\n"; + $name = $1; + $parameters{$name} = $contents; + } else { +# print STDERR "other section '$name' = '$contents'\n"; + $sections{$name} = $contents; + push @sectionlist, $name; + } +} + +## +# output function +# +# parameters, a hash. +# function => "function name" +# parameterlist => @list of parameters +# parameters => %parameter descriptions +# sectionlist => @list of sections +# sections => %descriont descriptions +# + +sub output_highlight { + my $contents = join "\n", @_; + my $line; + + eval $dohighlight; + foreach $line (split "\n", $contents) { + if ($line eq ""){ + print $lineprefix, $blankline; + } else { + $line =~ s/\\\\\\/\&/g; + print $lineprefix, $line; + } + print "\n"; + } +} + + +# output in html +sub output_html { + my %args = %{$_[0]}; + my ($parameter, $section); + my $count; + print "<h2>Function</h2>\n"; + + print "<i>".$args{'functiontype'}."</i>\n"; + print "<b>".$args{'function'}."</b>\n"; + print "("; + $count = 0; + foreach $parameter (@{$args{'parameterlist'}}) { + $type = $args{'parametertypes'}{$parameter}; + if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) { + # pointer-to-function + print "<i>$1</i><b>$parameter</b>) <i>($2)</i>"; + } else { + print "<i>".$type."</i> <b>".$parameter."</b>"; + } + if ($count != $#{$args{'parameterlist'}}) { + $count++; + print ",\n"; + } + } + print ")\n"; + + print "<h3>Arguments</h3>\n"; + print "<dl>\n"; + foreach $parameter (@{$args{'parameterlist'}}) { + print "<dt><b>".$parameter."</b>\n"; + print "<dd>"; + output_highlight($args{'parameters'}{$parameter}); + } + print "</dl>\n"; + foreach $section (@{$args{'sectionlist'}}) { + print "<h3>$section</h3>\n"; + print "<blockquote>\n"; + output_highlight($args{'sections'}{$section}); + print "</blockquote>\n"; + } + print "<hr>\n"; +} + + +# output in html +sub output_intro_html { + my %args = %{$_[0]}; + my ($parameter, $section); + my $count; + + foreach $section (@{$args{'sectionlist'}}) { + print "<h3>$section</h3>\n"; + print "<ul>\n"; + output_highlight($args{'sections'}{$section}); + print "</ul>\n"; + } + print "<hr>\n"; +} + + + +# output in sgml DocBook +sub output_sgml { + my %args = %{$_[0]}; + my ($parameter, $section); + my $count; + my $id; + + $id = "API-".$args{'function'}; + $id =~ s/[^A-Za-z0-9]/-/g; + + print "<refentry>\n"; + print "<refmeta>\n"; + print "<refentrytitle><phrase id=\"$id\">".$args{'function'}."</phrase></refentrytitle>\n"; + print "</refmeta>\n"; + print "<refnamediv>\n"; + print " <refname>".$args{'function'}."</refname>\n"; + print " <refpurpose>\n"; + print " "; + output_highlight ($args{'purpose'}); + print " </refpurpose>\n"; + print "</refnamediv>\n"; + + print "<refsynopsisdiv>\n"; + print " <title>Synopsis</title>\n"; + print " <funcsynopsis>\n"; + print " <funcdef>".$args{'functiontype'}." "; + print "<function>".$args{'function'}." "; + print "</function></funcdef>\n"; + +# print "<refsect1>\n"; +# print " <title>Synopsis</title>\n"; +# print " <funcsynopsis>\n"; +# print " <funcdef>".$args{'functiontype'}." "; +# print "<function>".$args{'function'}." "; +# print "</function></funcdef>\n"; + + $count = 0; + if ($#{$args{'parameterlist'}} >= 0) { + foreach $parameter (@{$args{'parameterlist'}}) { + $type = $args{'parametertypes'}{$parameter}; + if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) { + # pointer-to-function + print " <paramdef>$1<parameter>$parameter</parameter>)\n"; + print " <funcparams>$2</funcparams></paramdef>\n"; + } else { + print " <paramdef>".$type; + print " <parameter>$parameter</parameter></paramdef>\n"; + } + } + } else { + print " <void>\n"; + } + print " </funcsynopsis>\n"; + print "</refsynopsisdiv>\n"; +# print "</refsect1>\n"; + + # print parameters + print "<refsect1>\n <title>Arguments</title>\n"; +# print "<para>\nArguments\n"; + if ($#{$args{'parameterlist'}} >= 0) { + print " <variablelist>\n"; + foreach $parameter (@{$args{'parameterlist'}}) { + print " <varlistentry>\n <term><parameter>$parameter</parameter></term>\n"; + print " <listitem>\n <para>\n"; + $lineprefix=" "; + output_highlight($args{'parameters'}{$parameter}); + print " </para>\n </listitem>\n </varlistentry>\n"; + } + print " </variablelist>\n"; + } else { + print " <para>\n None\n </para>\n"; + } + print "</refsect1>\n"; + + # print out each section + $lineprefix=" "; + foreach $section (@{$args{'sectionlist'}}) { + print "<refsect1>\n <title>$section</title>\n <para>\n"; +# print "<para>\n$section\n"; + if ($section =~ m/EXAMPLE/i) { + print "<example><para>\n"; + } + output_highlight($args{'sections'}{$section}); +# print "</para>"; + if ($section =~ m/EXAMPLE/i) { + print "</para></example>\n"; + } + print " </para>\n</refsect1>\n"; + } + + print "</refentry>\n\n"; +} + +# output in sgml DocBook +sub output_intro_sgml { + my %args = %{$_[0]}; + my ($parameter, $section); + my $count; + my $id; + + $id = $args{'module'}; + $id =~ s/[^A-Za-z0-9]/-/g; + + # print out each section + $lineprefix=" "; + foreach $section (@{$args{'sectionlist'}}) { + print "<refsect1>\n <title>$section</title>\n <para>\n"; +# print "<para>\n$section\n"; + if ($section =~ m/EXAMPLE/i) { + print "<example><para>\n"; + } + output_highlight($args{'sections'}{$section}); +# print "</para>"; + if ($section =~ m/EXAMPLE/i) { + print "</para></example>\n"; + } + print " </para>\n</refsect1>\n"; + } + + print "\n\n"; +} + +# output in sgml DocBook +sub output_gnome { + my %args = %{$_[0]}; + my ($parameter, $section); + my $count; + my $id; + + $id = $args{'module'}."-".$args{'function'}; + $id =~ s/[^A-Za-z0-9]/-/g; + + print "<sect2>\n"; + print " <title id=\"$id\">".$args{'function'}."</title>\n"; + +# print "<simplesect>\n"; +# print " <title>Synopsis</title>\n"; + print " <funcsynopsis>\n"; + print " <funcdef>".$args{'functiontype'}." "; + print "<function>".$args{'function'}." "; + print "</function></funcdef>\n"; + + $count = 0; + if ($#{$args{'parameterlist'}} >= 0) { + foreach $parameter (@{$args{'parameterlist'}}) { + $type = $args{'parametertypes'}{$parameter}; + if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) { + # pointer-to-function + print " <paramdef>$1 <parameter>$parameter</parameter>)\n"; + print " <funcparams>$2</funcparams></paramdef>\n"; + } else { + print " <paramdef>".$type; + print " <parameter>$parameter</parameter></paramdef>\n"; + } + } + } else { + print " <void>\n"; + } + print " </funcsynopsis>\n"; +# print "</simplesect>\n"; +# print "</refsect1>\n"; + + # print parameters +# print "<simplesect>\n <title>Arguments</title>\n"; +# if ($#{$args{'parameterlist'}} >= 0) { +# print " <variablelist>\n"; +# foreach $parameter (@{$args{'parameterlist'}}) { +# print " <varlistentry>\n <term><parameter>$parameter</parameter></term>\n"; +# print " <listitem>\n <para>\n"; +# $lineprefix=" "; +# output_highlight($args{'parameters'}{$parameter}); +# print " </para>\n </listitem>\n </varlistentry>\n"; +# } +# print " </variablelist>\n"; +# } else { +# print " <para>\n None\n </para>\n"; +# } +# print "</simplesect>\n"; + +# print "<simplesect>\n <title>Arguments</title>\n"; + if ($#{$args{'parameterlist'}} >= 0) { + print " <informaltable pgwide=\"1\" frame=\"none\" role=\"params\">\n"; + print "<tgroup cols=\"2\">\n"; + print "<colspec colwidth=\"2*\">\n"; + print "<colspec colwidth=\"8*\">\n"; + print "<tbody>\n"; + foreach $parameter (@{$args{'parameterlist'}}) { + print " <row><entry align=\"right\"><parameter>$parameter</parameter></entry>\n"; + print " <entry>\n"; + $lineprefix=" "; + output_highlight($args{'parameters'}{$parameter}); + print " </entry></row>\n"; + } + print " </tbody></tgroup></informaltable>\n"; + } else { + print " <para>\n None\n </para>\n"; + } +# print "</simplesect>\n"; + + # print out each section + $lineprefix=" "; + foreach $section (@{$args{'sectionlist'}}) { + print "<simplesect>\n <title>$section</title>\n"; +# print "<para>\n$section\n"; + if ($section =~ m/EXAMPLE/i) { + print "<example><programlisting>\n"; + } else { + } + print "<para>\n"; + output_highlight($args{'sections'}{$section}); +# print "</para>"; + print "</para>\n"; + if ($section =~ m/EXAMPLE/i) { + print "</programlisting></example>\n"; + } else { + } + print " </simplesect>\n"; + } + + print "</sect2>\n\n"; +} + +## +# output in man +sub output_man { + my %args = %{$_[0]}; + my ($parameter, $section); + my $count; + + print ".TH \"$args{'module'}\" 4 \"$args{'function'}\" \"25 May 1998\" \"API Manual\" LINUX\n"; + + print ".SH NAME\n"; + print $args{'function'}." \\- ".$args{'purpose'}."\n"; + + print ".SH SYNOPSIS\n"; + print ".B \"".$args{'functiontype'}."\" ".$args{'function'}."\n"; + $count = 0; + $parenth = "("; + $post = ","; + foreach $parameter (@{$args{'parameterlist'}}) { + if ($count == $#{$args{'parameterlist'}}) { + $post = ");"; + } + $type = $args{'parametertypes'}{$parameter}; + if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) { + # pointer-to-function + print ".BI \"".$parenth.$1."\" ".$parameter." \") (".$2.")".$post."\"\n"; + } else { + $type =~ s/([^\*])$/\1 /; + print ".BI \"".$parenth.$type."\" ".$parameter." \"".$post."\"\n"; + } + $count++; + $parenth = ""; + } + + print ".SH Arguments\n"; + foreach $parameter (@{$args{'parameterlist'}}) { + print ".IP \"".$parameter."\" 12\n"; + output_highlight($args{'parameters'}{$parameter}); + } + foreach $section (@{$args{'sectionlist'}}) { + print ".SH \"$section\"\n"; + output_highlight($args{'sections'}{$section}); + } +} + +sub output_intro_man { + my %args = %{$_[0]}; + my ($parameter, $section); + my $count; + + print ".TH \"$args{'module'}\" 4 \"$args{'module'}\" \"25 May 1998\" \"API Manual\" LINUX\n"; + + foreach $section (@{$args{'sectionlist'}}) { + print ".SH \"$section\"\n"; + output_highlight($args{'sections'}{$section}); + } +} + +## +# output in text +sub output_text { + my %args = %{$_[0]}; + my ($parameter, $section); + + print "Function:\n\n"; + $start=$args{'functiontype'}." ".$args{'function'}." ("; + print $start; + $count = 0; + foreach $parameter (@{$args{'parameterlist'}}) { + if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) { + # pointer-to-function + print $1.$parameter.") (".$2; + } else { + print $type." ".$parameter; + } + if ($count != $#{$args{'parameterlist'}}) { + $count++; + print ",\n"; + print " " x length($start); + } else { + print ");\n\n"; + } + } + + print "Arguments:\n\n"; + foreach $parameter (@{$args{'parameterlist'}}) { + print $parameter."\n\t".$args{'parameters'}{$parameter}."\n"; + } + foreach $section (@{$args{'sectionlist'}}) { + print "$section:\n\n"; + output_highlight($args{'sections'}{$section}); + } + print "\n\n"; +} + +sub output_intro_text { + my %args = %{$_[0]}; + my ($parameter, $section); + + foreach $section (@{$args{'sectionlist'}}) { + print " $section:\n"; + print " -> "; + output_highlight($args{'sections'}{$section}); + } +} + +## +# generic output function - calls the right one based +# on current output mode. +sub output_function { +# output_html(@_); + eval "output_".$output_mode."(\@_);"; +} + +## +# generic output function - calls the right one based +# on current output mode. +sub output_intro { +# output_html(@_); + eval "output_intro_".$output_mode."(\@_);"; +} + + +## +# takes a function prototype and spits out all the details +# stored in the global arrays/hashes. +sub dump_function { + my $prototype = shift @_; + + $prototype =~ s/^static +//; + $prototype =~ s/^extern +//; + $prototype =~ s/^inline +//; + $prototype =~ s/^__inline__ +//; + $prototype =~ s/^#define +//; #ak added + + # Yes, this truly is vile. We are looking for: + # 1. Return type (may be nothing if we're looking at a macro) + # 2. Function name + # 3. Function parameters. + # + # All the while we have to watch out for function pointer parameters + # (which IIRC is what the two sections are for), C types (these + # regexps don't even start to express all the possibilities), and + # so on. + # + # If you mess with these regexps, it's a good idea to check that + # the following functions' documentation still comes out right: + # - parport_register_device (function pointer parameters) + # - atomic_set (macro) + # - pci_match_device (long return type) + + if ($prototype =~ m/^()([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ || + $prototype =~ m/^(\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ || + $prototype =~ m/^(\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ || + $prototype =~ m/^(\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ || + $prototype =~ m/^(\w+\s+\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ || + $prototype =~ m/^(\w+\s+\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ || + $prototype =~ m/^(\w+\s+\w+\s+\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\(]*)\)/ || + $prototype =~ m/^()([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ || + $prototype =~ m/^(\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ || + $prototype =~ m/^(\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ || + $prototype =~ m/^(\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ || + $prototype =~ m/^(\w+\s+\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ || + $prototype =~ m/^(\w+\s+\w+\s+\w+)\s+([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/ || + $prototype =~ m/^(\w+\s+\w+\s+\w+\s*\*)\s*([a-zA-Z0-9_~:]+)\s*\(([^\{]*)\)/) { + $return_type = $1; + $function_name = $2; + $args = $3; + + # allow for up to fours args to function pointers + $args =~ s/(\([^\),]+),/\1#/g; + $args =~ s/(\([^\),]+),/\1#/g; + $args =~ s/(\([^\),]+),/\1#/g; +# print STDERR "ARGS = '$args'\n"; + + foreach $arg (split ',', $args) { + # strip leading/trailing spaces + $arg =~ s/^\s*//; + $arg =~ s/\s*$//; + + if ($arg =~ m/\(/) { + # pointer-to-function + $arg =~ tr/#/,/; + $arg =~ m/[^\(]+\(\*([^\)]+)\)/; + $param = $1; + $type = $arg; + $type =~ s/([^\(]+\(\*)$param/\1/; + } else { + # evil magic to get fixed array parameters to work + $arg =~ s/(.+\s+)(.+)\[.*/\1* \2/; +# print STDERR "SCAN ARG: '$arg'\n"; + @args = split('\s', $arg); + +# print STDERR " -> @args\n"; + $param = pop @args; +# print STDERR " -> @args\n"; + if ($param =~ m/^(\*+)(.*)/) { + $param = $2; + push @args, $1; + } + $type = join " ", @args; + } + + if ($type eq "" && $param eq "...") + { + $type="..."; + $param="..."; + $parameters{"..."} = "variable arguments"; + } + elsif ($type eq "" && $param eq "") + { + $type=""; + $param="void"; + $parameters{void} = "no arguments"; + } + if ($type ne "" && $parameters{$param} eq "") { + $parameters{$param} = "-- undescribed --"; + print STDERR "Warning($file:$lineno): Function parameter '$param' not described in '$function_name'\n"; + } + + push @parameterlist, $param; + $parametertypes{$param} = $type; +# print STDERR "param = '$param', type = '$type'\n"; + } + } else { + print STDERR "Error($lineno): cannot understand prototype: '$prototype'\n"; + return; + } + + if ($function_only==0 || + ( $function_only == 1 && defined($function_table{$function_name})) || + ( $function_only == 2 && !defined($function_table{$function_name}))) + { + output_function({'function' => $function_name, + 'module' => $modulename, + 'functiontype' => $return_type, + 'parameterlist' => \@parameterlist, + 'parameters' => \%parameters, + 'parametertypes' => \%parametertypes, + 'sectionlist' => \@sectionlist, + 'sections' => \%sections, + 'purpose' => $function_purpose + }); + } +} + +###################################################################### +# main +# states +# 0 - normal code +# 1 - looking for function name +# 2 - scanning field start. +# 3 - scanning prototype. +$state = 0; +$section = ""; + +$doc_special = "\@\%\$\&"; + +$doc_start = "^/\\*\\*\\s*\$"; +$doc_end = "\\*/"; +$doc_com = "\\s*\\*\\s*"; +$doc_func = $doc_com."(\\w+):?"; +$doc_sect = $doc_com."([".$doc_special."]?[\\w ]+):(.*)"; +$doc_content = $doc_com."(.*)"; +$doc_block = $doc_com."DOC:\\s*(.*)?"; + +%constants = (); +%parameters = (); +@parameterlist = (); +%sections = (); +@sectionlist = (); + +$contents = ""; +$section_default = "Description"; # default section +$section_intro = "Introduction"; +$section = $section_default; + +while (<STDIN>) + { + if (/^!I(.*)/) + { + process_file("@top_srcdir@" . "/" . $1); + } + else + { + print; + } + } + +exit; + +sub process_file($) { + my ($file) = @_; + + if (!open(IN,"<$file")) { + print STDERR "Error: Cannot open file $file\n"; + return; + } + + $lineno = 0; + while (<IN>) { + $lineno++; + + if ($state == 0) { + if (/$doc_start/o) { + $state = 1; # next line is always the function name + } + } elsif ($state == 1) { # this line is the function name (always) + if (/$doc_block/o) { + $state = 4; + $contents = ""; + if ( $1 eq "" ) { + $section = $section_intro; + } else { + $section = $1; + } + } + elsif (/$doc_func/o) { + $function = $1; + $state = 2; + if (/-(.*)/) { + $function_purpose = $1; + } else { + $function_purpose = ""; + } + if ($verbose) { + print STDERR "Info($lineno): Scanning doc for $function\n"; + } + } else { + print STDERR "WARN($lineno): Cannot understand $_ on line $lineno", + " - I thought it was a doc line\n"; + $state = 0; + } + } elsif ($state == 2) { # look for head: lines, and include content + if (/$doc_sect/o) { + $newsection = $1; + $newcontents = $2; + + if ($contents ne "") { + $contents =~ s/\&/\\\\\\amp;/g; + $contents =~ s/\</\\\\\\lt;/g; + $contents =~ s/\>/\\\\\\gt;/g; + dump_section($section, $contents); + $section = $section_default; + } + + $contents = $newcontents; + if ($contents ne "") { + $contents .= "\n"; + } + $section = $newsection; + } elsif (/$doc_end/) { + + if ($contents ne "") { + $contents =~ s/\&/\\\\\\amp;/g; + $contents =~ s/\</\\\\\\lt;/g; + $contents =~ s/\>/\\\\\\gt;/g; + dump_section($section, $contents); + $section = $section_default; + $contents = ""; + } + +# print STDERR "end of doc comment, looking for prototype\n"; + $prototype = ""; + $state = 3; + } elsif (/$doc_content/) { + # miguel-style comment kludge, look for blank lines after + # @parameter line to signify start of description + if ($1 eq "" && $section =~ m/^@/) { + $contents =~ s/\&/\\\\\\amp;/g; + $contents =~ s/\</\\\\\\lt;/g; + $contents =~ s/\>/\\\\\\gt;/g; + dump_section($section, $contents); + $section = $section_default; + $contents = ""; + } else { + $contents .= $1."\n"; + } + } else { + # i dont know - bad line? ignore. + print STDERR "WARNING($lineno): bad line: $_"; + } + } elsif ($state == 3) { # scanning for function { (end of prototype) + if (m#\s*/\*\s+MACDOC\s*#io) { + # do nothing + } + elsif (/([^\{]*)/) { + $prototype .= $1; + } + if (/\{/ || /\#/ || /;/) { # added for #define AK + $prototype =~ s@/\*.*?\*/@@gos; # strip comments. + $prototype =~ s@[\r\n]+@ @gos; # strip newlines/cr's. + $prototype =~ s@^ +@@gos; # strip leading spaces + dump_function($prototype); + + $function = ""; + %constants = (); + %parameters = (); + %parametertypes = (); + @parameterlist = (); + %sections = (); + @sectionlist = (); + $prototype = ""; + + $state = 0; + } + } elsif ($state == 4) { + # Documentation block + if (/$doc_block/) { + dump_section($section, $contents); + output_intro({'sectionlist' => \@sectionlist, + 'sections' => \%sections }); + $contents = ""; + $function = ""; + %constants = (); + %parameters = (); + %parametertypes = (); + @parameterlist = (); + %sections = (); + @sectionlist = (); + $prototype = ""; + if ( $1 eq "" ) { + $section = $section_intro; + } else { + $section = $1; + } + } + elsif (/$doc_end/) + { + dump_section($section, $contents); + output_intro({'sectionlist' => \@sectionlist, + 'sections' => \%sections }); + $contents = ""; + $function = ""; + %constants = (); + %parameters = (); + %parametertypes = (); + @parameterlist = (); + %sections = (); + @sectionlist = (); + $prototype = ""; + $state = 0; + } + elsif (/$doc_content/) + { + if ( $1 eq "" ) + { + $contents .= $blankline; + } + else + { + $contents .= $1 . "\n"; + } + } + } + } +} + diff --git a/doc/manual.raw b/doc/manual.raw new file mode 100644 index 000000000..431e37200 --- /dev/null +++ b/doc/manual.raw @@ -0,0 +1,283 @@ +<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook V3.1//EN" [ +<!ENTITY efsd "<function>efsd</function>"> +]> + + +<book id="efsd-documentation-howto"> + <bookinfo> + <title>EFSD Documentation Howto</title> + + <authorgroup> + <author> + <firstname>FIRSTNAME</firstname> + <othername>OTHER</othername> + <surname>LASTNAME</surname> + <affiliation> + <address> + <email>EMAIL</email> + </address> + </affiliation> + </author> + </authorgroup> + + <copyright> + <year>2001</year> + <holder>Christian Kreibich</holder> + </copyright> + + <legalnotice> + <para> + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to + deal in the Software without restriction, including without limitation the + rights to use, copy, modify, merge, publish, distribute, sublicense, and/or + sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + </para> + <para> + The above copyright notice and this permission notice shall be included in + all copies of the Software and its documentation and acknowledgment shall be + given in the documentation and software packages that this Software was + used. + </para> + <para> + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER + IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + </para> + </legalnotice> + + <releaseinfo> + This is document is nowhere near being finished. Be patient. + </releaseinfo> + + </bookinfo> + + <toc></toc> + + <chapter id="introduction"> + <title>Introduction</title> + <para> + This is some sample documentation for you project. You'll need to be + familiar with <ulink url="http://docbook.org">DocBook</ulink> + to make best use of Enlightenment's documentation scheme. + </para> + <para> + See <link linkend="files" endterm="files.title"></link> + for an explanation of the documentation setup in you project. + </para> + <para> + <link linkend="comments" endterm="comments.title"></link> explains + the way you have to structure your comments so that they can be + extracted. + </para> + <para> + <link linkend="samples" endterm="samples.title"></link> contains a few + layout and markup examples to get you up to speed quickly. + </para> + </chapter> + + <chapter id="files"> + <title id="files.title">Documentation File Structure</title> + <para> + The entire documentation setup lives in the <filename>doc</filename> + directory. The file you need to edit is called <filename>manual.raw</filename>. + When you enter <command>make docs</command> in the toplevel directory, + it gets translated into a standard SGML file using a Perl script. + The script scans the file for any lines starting directly with the + string <command>!I<filename></command>. Here, + <filename>filename</filename> is the name of a code + file in which you have put extractable comments. The Perl script will + then analyze the file and generate SGML DocBook statements for those + comments right into the output file. + </para> + <para> + The resulting file of that step is called <filename>$PACKAGE-manual-$VERSION.sgml</filename> + where PACKAGE and VERSION are automatically set during the build process. + This sgml file can be postprocessed with any SGML processor to generate + for example HTML, TeX or PDF output. + </para> + <para> + Suppport for HTML generation is included already through the + <command>make html-docs</command> target. In order to be able to use + that, you'll need to have <command>jade</command> installed, and appropriate + DocBook stylesheets. If the <command>configure</command> script doesn't automatically find + you stylesheets (on a Debian system it should), you can specify them when + calling <command>configure</command> or <command>autogen.sh</command> using + the <command>--with-dbsheets=DIR</command> option. + </para> + <para> + If everything worked out fine, you'll get a tarball of the HTML version + of your documentation and the extracted version in the docs directory, + named similarly to the SGML file. + </para> + + </chapter> + + <chapter id="comments"> + <title id="comments.title">Writing Extractable Comments</title> + <para> + I'll simply give an example of a commented function here: + + <programlisting> + +/** + * efsd_wait_event - blocking wait for next Efsd event. + * @ec: The Efsd connection + * @ev: Pointer to an allocated EfsdEvent. + * + * Blocks until an efsd event arrives, then returns it by filling + * in the @ev structure. Returns -1 when there was an error, + * >= 0 otherwise. + */ +int efsd_wait_event(EfsdConnection *ec, EfsdEvent *ev); + </programlisting> + As you can see, it's not hard -- just use two asterisks + to signal the start of an extractable comment. In the first + line, begin with the function name and a one-liner description. + Then, put each parameter in the following lines. Add an empty + line, and then a more verbose description. That's basically + it, you can also markup items differently as follows: + + <itemizedlist mark="opencircle"> + <listitem> + <para><command>funcname()</command> for function names</para> + </listitem> + <listitem> + <para><command>$ENVVAR</command> for environment variables</para> + </listitem> + <listitem> + <para><command>&struct_name</command> for structures</para> + </listitem> + <listitem> + <para><command>%CONST</command> for constants/para> + </listitem> + </itemizedlist> + </para> + </chapter> + + <chapter id="samples"> + <title id="samples.title">DocBook Examples</title> + <section> + <title>Lists</title> + <para> + <itemizedlist mark="opencircle"> + <listitem> + <para>This</para> + </listitem> + <listitem> + <para>is</para> + </listitem> + <listitem> + <para>a</para> + </listitem> + <listitem> + <para>list</para> + </listitem> + </itemizedlist> + </para> + </section> + <section> + <title>Code</title> + <para> + <programlisting> + +EfsdConnection *ec; + +if ( (ec = efsd_open()) == NULL) + { + /* Oops. Couldn't establish connection. + * Is Efsd really running ? + */ + } + +/* ... various efsd commands ... */ + +if (efsd_close(ec) < 0) + { + /* Ouch. Error when closing connection. */ + } + </programlisting> + </para> + </section> + <section> + <title>Images</title> + <para> + + <mediaobject> + <imageobject> + <imagedata fileref="figures/sampleimage.eps" format="eps"> + </imageobject> + <imageobject> + <imagedata fileref="figures/sampleimage.gif" format="gif"> + </imageobject> + <textobject> + <phrase>Sample image</phrase> + </textobject> + <caption> + <para>This is how you display images.</para> + </caption> + </mediaobject> + + </para> + </section> + <section> + <title>Warnings, Notes</title> + <para> + <note> + <title>This is an example of a note.</title> + <para> + It's really simple to use. + </para> + </note + </para> + <para> + <caution> + <title>This is a warning.</title> + <para> + It's used just like a note. + </para> + </caution> + </para> + </section> + </chapter> + + <bibliography> + + <biblioentry id="bib-unp"> + <bookbiblio> + <author> + <firstname>W. R.</firstname> + <surname>Stevens</surname> + </author> + <title>UNIX Network Programming</title> + <edition>Second Edition</edition> + <volumenum>Volume 1</volumenum> + <publisher> + <publishername>Prentice-Hall</publishername> + </publisher> + <date>1998</date> + </bookbiblio> + </biblioentry> + + <biblioentry id="bib-apue"> + <bookbiblio> + <author> + <firstname>W. R.</firstname> + <surname>Stevens</surname> + </author> + <title>Advanced Programming in the UNIX Environment</title> + <publisher> + <publishername>Addison-Wesley</publishername> + </publisher> + <date>1992</date> + </bookbiblio> + </biblioentry> + + </bibliography> + +</book> + diff --git a/doc/stylesheet.css b/doc/stylesheet.css new file mode 100644 index 000000000..660965075 --- /dev/null +++ b/doc/stylesheet.css @@ -0,0 +1,20 @@ +body { margin-left:10px; + margin-right:10px; + margin-top:10px; + margin-bottom:10px; + color:#0000a0; + font-size:12pt; + background-image:url(figures/background.gif); + background-repeat:no-repeat; + } + +th { + font-size:14pt; + } + +td { + font-size:12pt; + } + +div.mediaobject { align:center; } +div.caption { align:center; } |