aboutsummaryrefslogtreecommitdiffstats
path: root/doxygen/filter_h.py
diff options
context:
space:
mode:
authorHåkan Jonsson <hakan.jonsson@ericsson.com>2016-09-13 10:44:32 +0200
committerKeith Burns <alagalah@gmail.com>2016-09-19 17:00:53 +0000
commitd3ba5e5b26c5c7c60df2aa31704c90997aaac2ad (patch)
tree391ce93f73c0cb88350a2eca100ee76a0bb6522e /doxygen/filter_h.py
parent864fa77d3738db12b0d43b53ad2f3761db8a69dd (diff)
doc: Initial doxygen framework for NSH SFC project
A first attempt for a documentation generation using Doxygen for the NSH SFC project. Doxygen tagging and documentation in the code still need to be done. Based on a copy of the Doxygen framework in VPP. Top Makefile added to (only) build documentation. Change-Id: I795dfd921dc3db1bf9fe901fb352edf8a3d65b50 Signed-off-by: Håkan Jonsson <hakan.jonsson@ericsson.com>
Diffstat (limited to 'doxygen/filter_h.py')
-rwxr-xr-xdoxygen/filter_h.py53
1 files changed, 53 insertions, 0 deletions
diff --git a/doxygen/filter_h.py b/doxygen/filter_h.py
new file mode 100755
index 0000000..967388d
--- /dev/null
+++ b/doxygen/filter_h.py
@@ -0,0 +1,53 @@
+#!/usr/bin/env python
+# Copyright (c) 2016 Comcast Cable Communications Management, LLC.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at:
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+# Filter for .c files to make various preprocessor tricks Doxygenish
+
+import os, sys, re
+
+if len(sys.argv) < 2:
+ sys.stderr.write("Usage: %s <filename>\n" % (sys.argv[0]))
+ sys.exit(1)
+
+replace_patterns = [
+ # Search for CLIB_PAD_FROM_TO(...); and replace with padding
+ # #define CLIB_PAD_FROM_TO(from,to) u8 pad_##from[(to) - (from)]
+ ( re.compile("(?P<m>CLIB_PAD_FROM_TO)\s*[(](?P<from>[^,]+),\s*(?P<to>[^)]+)[)]"),
+ r"/** Padding. */ u8 pad_\g<from>[(\g<to>) - (\g<from>)]" ),
+
+]
+
+
+filename = sys.argv[1]
+cwd = os.getcwd()
+if filename[0:len(cwd)] == cwd:
+ filename = filename[len(cwd):]
+ if filename[0] == "/":
+ filename = filename[1:]
+
+with open(filename) as fd:
+ line_num = 0
+
+ for line in fd:
+ line_num += 1
+ str = line[:-1] # filter \n
+
+ # Look for search/replace patterns
+ for p in replace_patterns:
+ str = p[0].sub(p[1], str)
+
+ sys.stdout.write(str+"\n")
+
+# All done