From a826ac9040225ea28de8daf1ba6eff4a6572ca41 Mon Sep 17 00:00:00 2001 From: Ben Pfaff Date: Wed, 18 Feb 2015 16:10:09 -0800 Subject: [PATCH] ovsdb-doc: Flag an error when a table or a column is left undocumented. This should make it harder to forget documentation. Signed-off-by: Ben Pfaff Acked-by: Gurucharan Shetty --- ovsdb/ovsdb-doc | 23 ++++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) diff --git a/ovsdb/ovsdb-doc b/ovsdb/ovsdb-doc index 620091559da..b670452381a 100755 --- a/ovsdb/ovsdb-doc +++ b/ovsdb/ovsdb-doc @@ -152,7 +152,7 @@ def typeAndConstraintsToNroff(column): type += " (must be unique within table)" return type -def columnGroupToNroff(table, groupXml): +def columnGroupToNroff(table, groupXml, documented_columns): introNodes = [] columnNodes = [] for node in groupXml.childNodes: @@ -172,6 +172,7 @@ def columnGroupToNroff(table, groupXml): for node in columnNodes: if node.tagName == 'column': name = node.attributes['name'].nodeValue + documented_columns.add(name) column = table.columns[name] if node.hasAttribute('key'): key = node.attributes['key'].nodeValue @@ -219,7 +220,8 @@ def columnGroupToNroff(table, groupXml): summary += [('column', nameNroff, typeNroff)] elif node.tagName == 'group': title = node.attributes["title"].nodeValue - subSummary, subIntro, subBody = columnGroupToNroff(table, node) + subSummary, subIntro, subBody = columnGroupToNroff( + table, node, documented_columns) summary += [('group', title, subSummary)] body += '.ST "%s:"\n' % textToNroff(title) body += subIntro + subBody @@ -242,15 +244,24 @@ def tableToNroff(schema, tableXml): tableName = tableXml.attributes['name'].nodeValue table = schema.tables[tableName] + documented_columns = set() s = """.bp .SH "%s TABLE" """ % tableName - summary, intro, body = columnGroupToNroff(table, tableXml) + summary, intro, body = columnGroupToNroff(table, tableXml, + documented_columns) s += intro s += '.SS "Summary:\n' s += tableSummaryToNroff(summary) s += '.SS "Details:\n' s += body + + schema_columns = set(table.columns.keys()) + undocumented_columns = schema_columns - documented_columns + for column in undocumented_columns: + raise error.Error("table %s has undocumented column %s" + % (tableName, column)) + return s def docsToNroff(schemaFile, xmlFile, erFile, title=None, version=None): @@ -306,6 +317,12 @@ def docsToNroff(schemaFile, xmlFile, erFile, title=None, version=None): else: introNodes += [dbNode] + documented_tables = set((name for (name, title) in summary)) + schema_tables = set(schema.tables.keys()) + undocumented_tables = schema_tables - documented_tables + for table in undocumented_tables: + raise error.Error("undocumented table %s" % table) + s += blockXmlToNroff(introNodes) + "\n" s += r"""