summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gnuradio-core/doc/Doxyfile.in194
-rwxr-xr-xgnuradio-core/doc/other/doxypy.py192
-rw-r--r--gnuradio-core/doc/other/group_defs.dox9
3 files changed, 247 insertions, 148 deletions
diff --git a/gnuradio-core/doc/Doxyfile.in b/gnuradio-core/doc/Doxyfile.in
index d83e65d40..048c0806c 100644
--- a/gnuradio-core/doc/Doxyfile.in
+++ b/gnuradio-core/doc/Doxyfile.in
@@ -25,7 +25,7 @@ DOXYFILE_ENCODING = UTF-8
# The PROJECT_NAME tag is a single word (or a sequence of words surrounded
# by quotes) that should identify the project.
-PROJECT_NAME = "GNU Radio @VERSION@"
+PROJECT_NAME = "GNU Radio @VERSION@ API"
# The PROJECT_NUMBER tag can be used to enter a project or revision number.
# This could be handy for archiving the generated documentation or
@@ -91,7 +91,7 @@ ABBREVIATE_BRIEF =
# Doxygen will generate a detailed section even if there is only a brief
# description.
-ALWAYS_DETAILED_SEC = NO
+ALWAYS_DETAILED_SEC = YES
# If the INLINE_INHERITED_MEMB tag is set to YES, doxygen will show all
# inherited members of a class in the documentation of that class as if those
@@ -152,7 +152,7 @@ QT_AUTOBRIEF = NO
# The new default is to treat a multi-line C++ comment block as a detailed
# description. Set this tag to YES if you prefer the old behaviour instead.
-MULTILINE_CPP_IS_BRIEF = NO
+MULTILINE_CPP_IS_BRIEF = YES
# If the DETAILS_AT_TOP tag is set to YES then Doxygen
# will output the detailed description near the top, like JavaDoc.
@@ -199,7 +199,7 @@ OPTIMIZE_OUTPUT_FOR_C = NO
# For instance, namespaces will be presented as packages, qualified scopes
# will look different, etc.
-OPTIMIZE_OUTPUT_JAVA = NO
+OPTIMIZE_OUTPUT_JAVA = YES
# If you use STL classes (i.e. std::string, std::vector, etc.) but do not want to
# include (a tag file for) the STL sources as input, then you should
@@ -249,7 +249,7 @@ EXTRACT_PRIVATE = NO
# If the EXTRACT_STATIC tag is set to YES all static members of a file
# will be included in the documentation.
-EXTRACT_STATIC = NO
+EXTRACT_STATIC = YES
# If the EXTRACT_LOCAL_CLASSES tag is set to YES classes (and structs)
# defined locally in source files will be included in the documentation.
@@ -262,7 +262,7 @@ EXTRACT_LOCAL_CLASSES = YES
# the interface are included in the documentation.
# If set to NO (the default) only methods in the interface are included.
-EXTRACT_LOCAL_METHODS = NO
+EXTRACT_LOCAL_METHODS = YES
# If this flag is set to YES, the members of anonymous namespaces will be extracted
# and appear in the documentation as a namespace called 'anonymous_namespace{file}',
@@ -354,7 +354,7 @@ SORT_BRIEF_DOCS = NO
# Note: This option applies only to the class list, not to the
# alphabetical list.
-SORT_BY_SCOPE_NAME = NO
+SORT_BY_SCOPE_NAME = YES
# The GENERATE_TODOLIST tag can be used to enable (YES) or
# disable (NO) the todo list. This list is created by putting \todo
@@ -424,7 +424,7 @@ FILE_VERSION_FILTER =
# The QUIET tag can be used to turn on/off the messages that are generated
# by doxygen. Possible values are YES and NO. If left blank NO is used.
-QUIET = NO
+QUIET = YES
# The WARNINGS tag can be used to turn on/off the warning messages that are
# generated by doxygen. Possible values are YES and NO. If left blank
@@ -495,7 +495,8 @@ INPUT_ENCODING = UTF-8
FILE_PATTERNS = *.h \
*.dox \
- *.py
+ *.py \
+ *.cc
# The RECURSIVE tag can be used to turn specify whether or not subdirectories
# should be searched for input files as well. Possible values are YES and NO.
@@ -510,17 +511,7 @@ RECURSIVE = YES
# We split these by top_srcdir and top_builddir (this matters in a VPATH build)
EXCLUDE = \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_filter.cc \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_filter.py \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_general.cc \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_general.py \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_gengen.cc \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_gengen.py \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_io.cc \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_io.py \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_runtime.cc \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_py_runtime.py \
- @abs_top_builddir@/gnuradio-core/src/lib/swig/gnuradio_swig_python.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/swig \
@abs_top_builddir@/gr-atsc/src/lib/atsc.cc \
@abs_top_builddir@/gr-atsc/src/lib/atsc.py \
@abs_top_builddir@/gr-audio-oss/src/audio_oss.py \
@@ -536,58 +527,80 @@ EXCLUDE = \
@abs_top_builddir@/gr-usrp/src/usrp1.py \
@abs_top_builddir@/gr-video-sdl/src/video_sdl.py \
@abs_top_builddir@/usrp/host/swig \
- @abs_top_srcdir@/docs \
- @abs_top_srcdir@/dtools \
- @abs_top_srcdir@/gnuradio-core/doc/doxypy/doxypy.py \
- @abs_top_srcdir@/gnuradio-core/doc/xml \
- @abs_top_srcdir@/gnuradio-core/src/lib/bug_work_around_6.cc \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/assembly.h \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_all.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_gr_fir_XXX.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_gr_fir_filter_XXX.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_gr_fir_sysconfig.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_gr_fir_sysconfig_generic.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_gr_fir_util.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_gr_freq_xlating_fir_filter_XXX.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_gr_interp_fir_filter_XXX.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_gr_rational_resampler_base_XXX.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/generate_utils.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/filter/sse_debug.h \
- @abs_top_srcdir@/gnuradio-core/src/lib/gengen/generate_all.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/gengen/generate_common.py \
- @abs_top_srcdir@/gnuradio-core/src/lib/missing/bug_work_around_8.cc \
- @abs_top_srcdir@/gnuradio-core/src/lib/runtime/gr_error_handler.cc \
- @abs_top_srcdir@/gnuradio-core/src/python/bin \
- @abs_top_srcdir@/gnuradio-core/src/python/build_utils.py \
- @abs_top_srcdir@/gnuradio-core/src/python/build_utils_codes.py \
- @abs_top_srcdir@/gnuradio-core/src/python/gnuradio/gr/gr_threading.py \
- @abs_top_srcdir@/gnuradio-core/src/python/gnuradio/gr/gr_threading_23.py \
- @abs_top_srcdir@/gnuradio-core/src/python/gnuradio/gr/gr_threading_24.py \
- @abs_top_srcdir@/gnuradio-core/src/tests \
- @abs_top_srcdir@/gnuradio-core/src/utils \
- @abs_top_srcdir@/gr-atsc/src/lib/gen_encoder.py \
- @abs_top_srcdir@/gr-atsc/src/python \
- @abs_top_srcdir@/gr-howto-write-a-block \
- @abs_top_srcdir@/gr-qtgui \
- @abs_top_srcdir@/gr-sounder/src/python/usrp_sounder.py \
- @abs_top_srcdir@/gr-trellis/doc \
- @abs_top_srcdir@/gr-trellis/src/lib/generate_all.py \
- @abs_top_srcdir@/gr-trellis/src/lib/generate_trellis.py \
- @abs_top_srcdir@/usrp/doc \
- @abs_top_srcdir@/usrp/firmware \
- @abs_top_srcdir@/usrp/fpga \
- @abs_top_srcdir@/usrp/host/apps \
- @abs_top_srcdir@/usrp/host/apps-inband \
- @abs_top_srcdir@/usrp/host/lib/inband \
- @abs_top_srcdir@/usrp/host/lib/legacy/ad9862.h \
- @abs_top_srcdir@/usrp/host/lib/legacy/check_data.py \
- @abs_top_srcdir@/usrp/host/lib/legacy/circular_buffer.h \
- @abs_top_srcdir@/usrp/host/lib/legacy/circular_linked_list.h \
- @abs_top_srcdir@/usrp/host/lib/legacy/dump_data.py \
- @abs_top_srcdir@/usrp/host/lib/legacy/gen_usrp_dbid.py \
- @abs_top_srcdir@/usrp/host/lib/legacy/usrp_dbid.py \
- @abs_top_srcdir@/usrp/host/misc \
- @abs_top_srcdir@/usrp/host/swig
+ @abs_top_builddir@/docs \
+ @abs_top_builddir@/dtools \
+ @abs_top_builddir@/gnuradio-core/doc/other/doxypy.py \
+ @abs_top_builddir@/gnuradio-core/doc/xml \
+ @abs_top_builddir@/gnuradio-core/doc/xml-swig \
+ @abs_top_builddir@/gnuradio-core/src/lib/bug_work_around_6.cc \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/assembly.h \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_all.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_gr_fir_XXX.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_gr_fir_filter_XXX.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_gr_fir_sysconfig.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_gr_fir_sysconfig_generic.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_gr_fir_util.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_gr_freq_xlating_fir_filter_XXX.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_gr_interp_fir_filter_XXX.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_gr_rational_resampler_base_XXX.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/generate_utils.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/sse_debug.h \
+ @abs_top_builddir@/gnuradio-core/src/lib/gengen/generate_all.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/gengen/generate_common.py \
+ @abs_top_builddir@/gnuradio-core/src/lib/missing/bug_work_around_8.cc \
+ @abs_top_builddir@/gnuradio-core/src/lib/runtime/gr_error_handler.cc \
+ @abs_top_builddir@/gnuradio-core/src/python/bin \
+ @abs_top_builddir@/gnuradio-core/src/python/build_utils.py \
+ @abs_top_builddir@/gnuradio-core/src/python/build_utils_codes.py \
+ @abs_top_builddir@/gnuradio-core/src/python/gnuradio/gr/gr_threading.py \
+ @abs_top_builddir@/gnuradio-core/src/python/gnuradio/gr/gr_threading_23.py \
+ @abs_top_builddir@/gnuradio-core/src/python/gnuradio/gr/gr_threading_24.py \
+ @abs_top_builddir@/gnuradio-core/src/tests \
+ @abs_top_builddir@/gnuradio-core/src/utils \
+ @abs_top_builddir@/gr-atsc/src/lib/gen_encoder.py \
+ @abs_top_builddir@/gr-atsc/src/python \
+ @abs_top_builddir@/gr-howto-write-a-block \
+ @abs_top_builddir@/gr-qtgui \
+ @abs_top_builddir@/gr-sounder/src/python/usrp_sounder.py \
+ @abs_top_builddir@/gr-trellis/doc \
+ @abs_top_builddir@/gr-trellis/src/lib/generate_all.py \
+ @abs_top_builddir@/gr-trellis/src/lib/generate_trellis.py \
+ @abs_top_builddir@/usrp/doc \
+ @abs_top_builddir@/usrp/firmware \
+ @abs_top_builddir@/usrp/fpga \
+ @abs_top_builddir@/usrp/host/apps \
+ @abs_top_builddir@/usrp/host/apps-inband \
+ @abs_top_builddir@/usrp/host/lib/inband \
+ @abs_top_builddir@/usrp/host/lib/legacy/ad9862.h \
+ @abs_top_builddir@/usrp/host/lib/legacy/check_data.py \
+ @abs_top_builddir@/usrp/host/lib/legacy/circular_buffer.h \
+ @abs_top_builddir@/usrp/host/lib/legacy/circular_linked_list.h \
+ @abs_top_builddir@/usrp/host/lib/legacy/dump_data.py \
+ @abs_top_builddir@/usrp/host/lib/legacy/gen_usrp_dbid.py \
+ @abs_top_builddir@/usrp/host/lib/legacy/usrp_dbid.py \
+ @abs_top_builddir@/usrp/host/misc \
+ @abs_top_builddir@/usrp/host/swig \
+ @abs_top_builddir@/grc \
+ @abs_top_builddir@/gr-wxgui/src/python \
+ @abs_top_builddir@/gr-radio-astronomy/src/python \
+ @abs_top_builddir@/omnithread/nt.cc \
+ @abs_top_builddir@/omnithread/mach.cc \
+ @abs_top_builddir@/gr-audio-alsa/src/audio-alsa.py \
+ @abs_top_builddir@/gr-msdd6000/src/msdd.py \
+ @abs_top_builddir@/gr-usrp2/src/usrp2.py \
+ @abs_top_builddir@/usrp/host/lib/legacy/db_flexrf.h \
+ @abs_top_builddir@/usrp/host/lib/legacy/db_flexrf_mimo.h \
+ @abs_top_builddir@/usrp/host/lib/legacy/db_wbx.h \
+ @abs_top_builddir@/gnuradio-core/doc/other/shared_ptr_docstub.h \
+ @abs_top_builddir@/gnuradio-core/doc/other/vector_docstub.h \
+ @abs_top_builddir@/gnuradio-core/src/lib/missing/getopt.h \
+ @abs_top_builddir@/gnuradio-core/src/lib/filter/gr_altivec.h \
+ @abs_top_builddir@/gnuradio-examples/python/apps/hf_radio/output.py \
+ @abs_top_builddir@/gnuradio-examples/python/apps/hf_radio/ui.py \
+ @abs_top_builddir@/gr-radio-astronomy/src/lib/ra.py \
+ @abs_top_builddir@/gcell/ibm/sync/ppu_source/cond.h \
+ @abs_top_builddir@/gcell/ibm/sync/ppu_source/libsync.h \
+ @abs_top_builddir@/gcell/ibm/sync/spu_source/sync_utils.h
# The EXCLUDE_SYMLINKS tag can be used select whether or not files or
@@ -624,7 +637,26 @@ EXCLUDE_PATTERNS = \
EXCLUDE_SYMBOLS = ad9862 \
numpy \
- usrpm
+ usrpm \
+ *swig* \
+ *Swig* \
+ *my_top_block* \
+ *my_graph* \
+ *app_top_block* \
+ *am_rx_graph* \
+ *_queue_watcher_thread* \
+ *parse* \
+ *MyFrame* \
+ *MyApp* \
+ *PyObject* \
+ *wfm_rx_block* \
+ *_sptr* \
+ *debug* \
+ *wfm_rx_sca_block* \
+ *tv_rx_block* \
+ *wxapt_rx_block* \
+ *example_signal*
+
# The EXAMPLE_PATH tag can be used to specify one or more files or
# directories that contain example code fragments that are included (see
@@ -676,7 +708,7 @@ FILTER_PATTERNS = *.py=@top_srcdir@/gnuradio-core/doc/other/doxypy.py
# INPUT_FILTER) will be used to filter the input files when producing source
# files to browse (i.e. when SOURCE_BROWSER is set to YES).
-FILTER_SOURCE_FILES = YES
+FILTER_SOURCE_FILES = NO
#---------------------------------------------------------------------------
# configuration options related to source browsing
@@ -689,7 +721,7 @@ FILTER_SOURCE_FILES = YES
# then you must also enable this option. If you don't then doxygen will produce
# a warning and turn it on anyway
-SOURCE_BROWSER = NO
+SOURCE_BROWSER = YES
# Setting the INLINE_SOURCES tag to YES will include the body
# of functions and classes directly in the documentation.
@@ -700,7 +732,7 @@ INLINE_SOURCES = NO
# doxygen to hide any special comment blocks from generated source code
# fragments. Normal C and C++ comments will always remain visible.
-STRIP_CODE_COMMENTS = YES
+STRIP_CODE_COMMENTS = NO
# If the REFERENCED_BY_RELATION tag is set to YES (the default)
# then for each documented function all documented
@@ -743,7 +775,7 @@ VERBATIM_HEADERS = YES
# of all compounds will be generated. Enable this if the project
# contains a lot of classes, structs, unions or interfaces.
-ALPHABETICAL_INDEX = NO
+ALPHABETICAL_INDEX = YES
# If the alphabetical index is enabled (see ALPHABETICAL_INDEX) then
# the COLS_IN_ALPHA_INDEX tag can be used to specify the number of columns
@@ -850,13 +882,13 @@ BINARY_TOC = NO
# The TOC_EXPAND flag can be set to YES to add extra items for group members
# to the contents of the HTML help documentation and to the tree view.
-TOC_EXPAND = NO
+TOC_EXPAND = YES
# The DISABLE_INDEX tag can be used to turn on/off the condensed index at
# top of each HTML page. The value NO (the default) enables the index and
# the value YES disables it.
-DISABLE_INDEX = NO
+DISABLE_INDEX = YES
# This tag can be used to set the number of enum values (range [1..20])
# that doxygen will group on one line in the generated HTML documentation.
@@ -870,13 +902,13 @@ ENUM_VALUES_PER_LINE = 4
# Netscape 6.0+, Internet explorer 5.0+, or Konqueror). Windows users are
# probably better off using the HTML help feature.
-GENERATE_TREEVIEW = NO
+GENERATE_TREEVIEW = YES
# If the treeview is enabled (see GENERATE_TREEVIEW) then this tag can be
# used to set the initial width (in pixels) of the frame in which the tree
# is shown.
-TREEVIEW_WIDTH = 250
+TREEVIEW_WIDTH = 180
#---------------------------------------------------------------------------
# configuration options related to the LaTeX output
diff --git a/gnuradio-core/doc/other/doxypy.py b/gnuradio-core/doc/other/doxypy.py
index 34353b6ac..82fdb6bea 100755
--- a/gnuradio-core/doc/other/doxypy.py
+++ b/gnuradio-core/doc/other/doxypy.py
@@ -15,8 +15,8 @@ add the following lines to your Doxyfile:
INPUT_FILTER = "python /path/to/doxypy.py"
"""
-__version__ = "0.3rc2"
-__date__ = "18th December 2007"
+__version__ = "0.4.1"
+__date__ = "5th December 2008"
__website__ = "http://code.foosel.org/doxypy"
__author__ = (
@@ -45,11 +45,19 @@ import re
from optparse import OptionParser, OptionGroup
class FSM(object):
- """ FSM implements a finite state machine. Transitions are given as
- 4-tuples, consisting of an origin state, a target state, a condition
- for the transition (given as a reference to a function which gets called
- with a given piece of input) and a pointer to a function to be called
- upon the execution of the given transition.
+ """Implements a finite state machine.
+
+ Transitions are given as 4-tuples, consisting of an origin state, a target
+ state, a condition for the transition (given as a reference to a function
+ which gets called with a given piece of input) and a pointer to a function
+ to be called upon the execution of the given transition.
+ """
+
+ """
+ @var transitions holds the transitions
+ @var current_state holds the current state
+ @var current_input holds the current input
+ @var current_transition hold the currently active transition
"""
def __init__(self, start_state=None, transitions=[]):
@@ -66,7 +74,8 @@ class FSM(object):
def makeTransition(self, input):
""" Makes a transition based on the given input.
- @param input input to parse by the FSM
+
+ @param input input to parse by the FSM
"""
for transition in self.transitions:
[from_state, to_state, condition, callback] = transition
@@ -76,20 +85,23 @@ class FSM(object):
self.current_state = to_state
self.current_input = input
self.current_transition = transition
+ if options.debug:
+ print >>sys.stderr, "# FSM: executing (%s -> %s) for line '%s'" % (from_state, to_state, input)
callback(match)
return
-
class Doxypy(object):
def __init__(self):
- self.start_single_comment_re = re.compile("^\s*(''')")
+ string_prefixes = "[uU]?[rR]?"
+
+ self.start_single_comment_re = re.compile("^\s*%s(''')" % string_prefixes)
self.end_single_comment_re = re.compile("(''')\s*$")
- self.start_double_comment_re = re.compile("^\s*(\"\"\")")
+ self.start_double_comment_re = re.compile("^\s*%s(\"\"\")" % string_prefixes)
self.end_double_comment_re = re.compile("(\"\"\")\s*$")
- self.single_comment_re = re.compile("^\s*(''').*(''')\s*$")
- self.double_comment_re = re.compile("^\s*(\"\"\").*(\"\"\")\s*$")
+ self.single_comment_re = re.compile("^\s*%s(''').*(''')\s*$" % string_prefixes)
+ self.double_comment_re = re.compile("^\s*%s(\"\"\").*(\"\"\")\s*$" % string_prefixes)
self.defclass_re = re.compile("^(\s*)(def .+:|class .+:)")
self.empty_re = re.compile("^\s*$")
@@ -141,6 +153,7 @@ class Doxypy(object):
# other lines
["DEFCLASS", "DEFCLASS", self.empty_re.search, self.appendDefclassLine],
["DEFCLASS", "DEFCLASS", self.defclass_re.search, self.resetCommentSearch],
+ ["DEFCLASS", "DEFCLASS_MULTI", self.multiline_defclass_start_re.search, self.resetCommentSearch],
["DEFCLASS", "DEFCLASS_BODY", self.catchall, self.stopCommentSearch],
### DEFCLASS_BODY
@@ -155,16 +168,16 @@ class Doxypy(object):
]
self.fsm = FSM("FILEHEAD", transitions)
+ self.outstream = sys.stdout
self.output = []
-
self.comment = []
self.filehead = []
self.defclass = []
self.indent = ""
def __closeComment(self):
- """ Appends any open comment block and triggering block to the output. """
+ """Appends any open comment block and triggering block to the output."""
if options.autobrief:
if len(self.comment) == 1 \
@@ -179,59 +192,90 @@ class Doxypy(object):
self.output.extend(self.defclass)
def __docstringSummaryToBrief(self, line):
- """ Adds \\brief to the docstrings summary line.
+ """Adds \\brief to the docstrings summary line.
- A \\brief is prepended, provided no other doxygen command is at the start of the line.
+ A \\brief is prepended, provided no other doxygen command is at the
+ start of the line.
"""
stripped = line.strip()
if stripped and not stripped[0] in ('@', '\\'):
return "\\brief " + line
else:
return line
+
+ def __flushBuffer(self):
+ """Flushes the current outputbuffer to the outstream."""
+ if self.output:
+ try:
+ if options.debug:
+ print >>sys.stderr, "# OUTPUT: ", self.output
+ print >>self.outstream, "\n".join(self.output)
+ self.outstream.flush()
+ except IOError:
+ # Fix for FS#33. Catches "broken pipe" when doxygen closes
+ # stdout prematurely upon usage of INPUT_FILTER, INLINE_SOURCES
+ # and FILTER_SOURCE_FILES.
+ pass
+ self.output = []
def catchall(self, input):
- """ The catchall-condition, always returns true. """
+ """The catchall-condition, always returns true."""
return True
def resetCommentSearch(self, match):
- """ Restarts a new comment search for a different triggering line.
- Closes the current commentblock and starts a new comment search.
+ """Restarts a new comment search for a different triggering line.
+
+ Closes the current commentblock and starts a new comment search.
"""
+ if options.debug:
+ print >>sys.stderr, "# CALLBACK: resetCommentSearch"
self.__closeComment()
self.startCommentSearch(match)
def startCommentSearch(self, match):
- """ Starts a new comment search.
- Saves the triggering line, resets the current comment and saves
- the current indentation.
+ """Starts a new comment search.
+
+ Saves the triggering line, resets the current comment and saves
+ the current indentation.
"""
+ if options.debug:
+ print >>sys.stderr, "# CALLBACK: startCommentSearch"
self.defclass = [self.fsm.current_input]
self.comment = []
self.indent = match.group(1)
def stopCommentSearch(self, match):
- """ Stops a comment search.
- Closes the current commentblock, resets the triggering line and
- appends the current line to the output.
+ """Stops a comment search.
+
+ Closes the current commentblock, resets the triggering line and
+ appends the current line to the output.
"""
+ if options.debug:
+ print >>sys.stderr, "# CALLBACK: stopCommentSearch"
self.__closeComment()
self.defclass = []
self.output.append(self.fsm.current_input)
def appendFileheadLine(self, match):
- """ Appends a line in the FILEHEAD state.
- Closes the open comment block, resets it and appends the current line.
+ """Appends a line in the FILEHEAD state.
+
+ Closes the open comment block, resets it and appends the current line.
"""
+ if options.debug:
+ print >>sys.stderr, "# CALLBACK: appendFileheadLine"
self.__closeComment()
self.comment = []
self.output.append(self.fsm.current_input)
def appendCommentLine(self, match):
- """ Appends a comment line.
- The comment delimiter is removed from multiline start and ends as
- well as singleline comments.
+ """Appends a comment line.
+
+ The comment delimiter is removed from multiline start and ends as
+ well as singleline comments.
"""
+ if options.debug:
+ print >>sys.stderr, "# CALLBACK: appendCommentLine"
(from_state, to_state, condition, callback) = self.fsm.current_transition
# single line comment
@@ -266,17 +310,22 @@ class Doxypy(object):
self.comment.append(self.fsm.current_input)
def appendNormalLine(self, match):
- """ Appends a line to the output. """
+ """Appends a line to the output."""
+ if options.debug:
+ print >>sys.stderr, "# CALLBACK: appendNormalLine"
self.output.append(self.fsm.current_input)
def appendDefclassLine(self, match):
- """ Appends a line to the triggering block. """
+ """Appends a line to the triggering block."""
+ if options.debug:
+ print >>sys.stderr, "# CALLBACK: appendDefclassLine"
self.defclass.append(self.fsm.current_input)
def makeCommentBlock(self):
- """ Indents the current comment block with respect to the current
- indentation level.
- @returns a list of indented comment lines
+ """Indents the current comment block with respect to the current
+ indentation level.
+
+ @returns a list of indented comment lines
"""
doxyStart = "##"
commentLines = self.comment
@@ -288,42 +337,59 @@ class Doxypy(object):
return l
def parse(self, input):
- """ Parses a python file given as input string and returns the doxygen-
- compatible representation.
- @param input the python code to parse
- @returns the modified python code
+ """Parses a python file given as input string and returns the doxygen-
+ compatible representation.
+
+ @param input the python code to parse
+ @returns the modified python code
"""
lines = input.split("\n")
for line in lines:
self.fsm.makeTransition(line)
-
+
if self.fsm.current_state == "DEFCLASS":
self.__closeComment()
return "\n".join(self.output)
-def loadFile(filename):
- """ Loads file "filename" and returns the content.
- @param filename The name of the file to load
- @returns the content of the file.
- """
- f = open(filename, 'r')
-
- try:
- content = f.read()
- return content
- finally:
+ def parseFile(self, filename):
+ """Parses a python file given as input string and returns the doxygen-
+ compatible representation.
+
+ @param input the python code to parse
+ @returns the modified python code
+ """
+ f = open(filename, 'r')
+
+ for line in f:
+ self.parseLine(line.rstrip('\r\n'))
+ if self.fsm.current_state == "DEFCLASS":
+ self.__closeComment()
+ self.__flushBuffer()
f.close()
-
+
+ def parseLine(self, line):
+ """Parse one line of python and flush the resulting output to the
+ outstream.
+
+ @param line the python code line to parse
+ """
+ self.fsm.makeTransition(line)
+ self.__flushBuffer()
+
def optParse():
- """ Parses commandline options. """
+ """Parses commandline options."""
parser = OptionParser(prog=__applicationName__, version="%prog " + __version__)
parser.set_usage("%prog [options] filename")
parser.add_option("--autobrief",
action="store_true", dest="autobrief",
- help="Use the docstring summary line as \\brief description"
+ help="use the docstring summary line as \\brief description"
+ )
+ parser.add_option("--debug",
+ action="store_true", dest="debug",
+ help="enable debug output on stderr"
)
## parse options
@@ -337,20 +403,12 @@ def optParse():
return filename[0]
def main():
- """ Opens the file given as first commandline argument and processes it,
- then prints out the processed file.
+ """Starts the parser on the file given by the filename as the first
+ argument on the commandline.
"""
filename = optParse()
-
- try:
- input = loadFile(filename)
- except IOError, (errno, msg):
- print >>sys.stderr, msg
- sys.exit(-1)
-
fsm = Doxypy()
- output = fsm.parse(input)
- print output
+ fsm.parseFile(filename)
if __name__ == "__main__":
- main() \ No newline at end of file
+ main()
diff --git a/gnuradio-core/doc/other/group_defs.dox b/gnuradio-core/doc/other/group_defs.dox
index 77cb58612..7373236ce 100644
--- a/gnuradio-core/doc/other/group_defs.dox
+++ b/gnuradio-core/doc/other/group_defs.dox
@@ -38,6 +38,14 @@
* \defgroup synch Synchronization
*/
+/*!
+ * \defgroup packet Packetization
+ */
+
+/*!
+ * \defgroup logic Logical
+ */
+
/*! @} */
/*! \defgroup filter_design Digital Filter Design */
@@ -83,4 +91,5 @@
/*! @} */
/*! \defgroup usrp USRP */
+/*! \defgroup usrp2 USRP2 */
/*! \defgroup hardware Hardware */