quick and dirty module doc updates (#18944)

clean up core/extras, plumb in basic metadata display
This commit is contained in:
Matt Davis 2016-12-07 14:50:17 -08:00 committed by Matt Clay
parent 250b0dff46
commit 0b47c908eb
4 changed files with 19 additions and 26 deletions

View file

@ -4,9 +4,9 @@ Core Modules
These are modules that the core ansible team maintains and will always ship with ansible itself. These are modules that the core ansible team maintains and will always ship with ansible itself.
They will also receive slightly higher priority for all requests than those in the "extras" repos. They will also receive slightly higher priority for all requests than those in the "extras" repos.
The source of these modules is hosted on GitHub in the `ansible-modules-core <http://github.com/ansible/ansible-modules-core>`_ repo. The source of these modules is hosted on GitHub in the `ansible <https://github.com/ansible/ansible/tree/devel/lib/ansible/modules>`_ repo.
If you believe you have found a bug in a core module and are already running the latest stable or development version of Ansible, first look in the `issue tracker at github.com/ansible/ansible-modules-core <http://github.com/ansible/ansible-modules-core>`_ to see if a bug has already been filed. If not, we would be grateful if you would file one. If you believe you have found a bug in a core module and are already running the latest stable or development version of Ansible, first look in the `issue tracker at github.com/ansible/ansible <http://github.com/ansible/ansible/issues>`_ to see if a bug has already been filed. If not, we would be grateful if you would file one.
Should you have a question rather than a bug report, inquiries are welcome on the `ansible-project google group <https://groups.google.com/forum/#!forum/ansible-project>`_ or on Ansible's "#ansible" channel, located on irc.freenode.net. Development oriented topics should instead use the similar `ansible-devel google group <https://groups.google.com/forum/#!forum/ansible-devel>`_. Should you have a question rather than a bug report, inquiries are welcome on the `ansible-project google group <https://groups.google.com/forum/#!forum/ansible-project>`_ or on Ansible's "#ansible" channel, located on irc.freenode.net. Development oriented topics should instead use the similar `ansible-devel google group <https://groups.google.com/forum/#!forum/ansible-devel>`_.

View file

@ -6,10 +6,10 @@ Non-core modules are still fully usable, but may receive slightly lower response
Popular "extras" modules may be promoted to core modules over time. Popular "extras" modules may be promoted to core modules over time.
The source for these modules is hosted on GitHub in the `ansible-modules-extras <http://github.com/ansible/ansible-modules-extras>`_ repo. The source for these modules is hosted on GitHub in the `ansible <https://github.com/ansible/ansible/tree/devel/lib/ansible/modules>`_ repo.
If you believe you have found a bug in an extras module and are already running the latest stable or development version of Ansible, If you believe you have found a bug in an extras module and are already running the latest stable or development version of Ansible,
first look in the `issue tracker at github.com/ansible/ansible-modules-extras <http://github.com/ansible/ansible-modules-extras>`_ first look in the `issue tracker at github.com/ansible/ansible <http://github.com/ansible/ansible/issues>`_
to see if a bug has already been filed. If not, we would be grateful if you could file one. to see if a bug has already been filed. If not, we would be grateful if you could file one.
Should you have a question rather than a bug report, inquiries are welcome on the `ansible-project google group <https://groups.google.com/forum/#!forum/ansible-project>`_ Should you have a question rather than a bug report, inquiries are welcome on the `ansible-project google group <https://groups.google.com/forum/#!forum/ansible-project>`_

View file

@ -64,7 +64,6 @@ _URL = re.compile(r"U\(([^)]+)\)")
_CONST = re.compile(r"C\(([^)]+)\)") _CONST = re.compile(r"C\(([^)]+)\)")
DEPRECATED = " (D)" DEPRECATED = " (D)"
NOTCORE = " (E)"
##################################################################################### #####################################################################################
def rst_ify(text): def rst_ify(text):
@ -258,15 +257,14 @@ def process_module(module, options, env, template, outputname, module_map, alias
sys.stderr.write("*** ERROR: MODULE MISSING DOCUMENTATION: %s, %s ***\n" % (fname, module)) sys.stderr.write("*** ERROR: MODULE MISSING DOCUMENTATION: %s, %s ***\n" % (fname, module))
sys.exit(1) sys.exit(1)
if metadata is None:
sys.stderr.write("*** ERROR: MODULE MISSING METADATA: %s, %s ***\n" % (fname, module))
sys.exit(1)
if deprecated and 'deprecated' not in doc: if deprecated and 'deprecated' not in doc:
sys.stderr.write("*** ERROR: DEPRECATED MODULE MISSING 'deprecated' DOCUMENTATION: %s, %s ***\n" % (fname, module)) sys.stderr.write("*** ERROR: DEPRECATED MODULE MISSING 'deprecated' DOCUMENTATION: %s, %s ***\n" % (fname, module))
sys.exit(1) sys.exit(1)
if "/core/" in fname:
doc['core'] = True
else:
doc['core'] = False
if module in aliases: if module in aliases:
doc['aliases'] = aliases[module] doc['aliases'] = aliases[module]
@ -310,6 +308,8 @@ def process_module(module, options, env, template, outputname, module_map, alias
doc['now_date'] = datetime.date.today().strftime('%Y-%m-%d') doc['now_date'] = datetime.date.today().strftime('%Y-%m-%d')
doc['ansible_version'] = options.ansible_version doc['ansible_version'] = options.ansible_version
doc['plainexamples'] = examples #plain text doc['plainexamples'] = examples #plain text
doc['metadata'] = metadata
if returndocs: if returndocs:
try: try:
doc['returndocs'] = yaml.safe_load(returndocs) doc['returndocs'] = yaml.safe_load(returndocs)
@ -330,15 +330,13 @@ def process_module(module, options, env, template, outputname, module_map, alias
##################################################################################### #####################################################################################
def print_modules(module, category_file, deprecated, core, options, env, template, outputname, module_map, aliases): def print_modules(module, category_file, deprecated, options, env, template, outputname, module_map, aliases):
modstring = module modstring = module
if modstring.startswith('_'): if modstring.startswith('_'):
modstring = module[1:] modstring = module[1:]
modname = modstring modname = modstring
if module in deprecated: if module in deprecated:
modstring = modstring + DEPRECATED modstring = modstring + DEPRECATED
elif module not in core:
modstring = modstring + NOTCORE
category_file.write(" %s - %s <%s_module>\n" % (to_bytes(modstring), to_bytes(rst_ify(module_map[module][1])), to_bytes(modname))) category_file.write(" %s - %s <%s_module>\n" % (to_bytes(modstring), to_bytes(rst_ify(module_map[module][1])), to_bytes(modname)))
@ -374,21 +372,16 @@ def process_category(category, categories, options, env, template, outputname):
modules = [] modules = []
deprecated = [] deprecated = []
core = []
for module in module_map.keys(): for module in module_map.keys():
if isinstance(module_map[module], dict): if isinstance(module_map[module], dict):
for mod in (m for m in module_map[module].keys() if m in module_info): for mod in (m for m in module_map[module].keys() if m in module_info):
if mod.startswith("_"): if mod.startswith("_"):
deprecated.append(mod) deprecated.append(mod)
elif '/core/' in module_info[mod][0]:
core.append(mod)
else: else:
if module not in module_info: if module not in module_info:
continue continue
if module.startswith("_"): if module.startswith("_"):
deprecated.append(module) deprecated.append(module)
elif '/core/' in module_info[module][0]:
core.append(module)
modules.append(module) modules.append(module)
modules.sort(key=lambda k: k[1:] if k.startswith('_') else k) modules.sort(key=lambda k: k[1:] if k.startswith('_') else k)
@ -409,7 +402,7 @@ def process_category(category, categories, options, env, template, outputname):
sections.append(module) sections.append(module)
continue continue
else: else:
print_modules(module, category_file, deprecated, core, options, env, template, outputname, module_info, aliases) print_modules(module, category_file, deprecated, options, env, template, outputname, module_info, aliases)
sections.sort() sections.sort()
for section in sections: for section in sections:
@ -420,14 +413,12 @@ def process_category(category, categories, options, env, template, outputname):
section_modules.sort(key=lambda k: k[1:] if k.startswith('_') else k) section_modules.sort(key=lambda k: k[1:] if k.startswith('_') else k)
#for module in module_map[section]: #for module in module_map[section]:
for module in (m for m in section_modules if m in module_info): for module in (m for m in section_modules if m in module_info):
print_modules(module, category_file, deprecated, core, options, env, template, outputname, module_info, aliases) print_modules(module, category_file, deprecated, options, env, template, outputname, module_info, aliases)
category_file.write("""\n\n category_file.write("""\n\n
.. note:: .. note::
- %s: This marks a module as deprecated, which means a module is kept for backwards compatibility but usage is discouraged. The module documentation details page may explain more about this rationale. - %s: This marks a module as deprecated, which means a module is kept for backwards compatibility but usage is discouraged. The module documentation details page may explain more about this rationale.
- %s: This marks a module as 'extras', which means it ships with ansible but may be a newer module and possibly (but not necessarily) less actively maintained than 'core' modules. """ % DEPRECATED)
- Tickets filed on modules are filed to different repos than those on the main open source project. Core module tickets should be filed at `ansible/ansible-modules-core on GitHub <http://github.com/ansible/ansible-modules-core>`_, extras tickets to `ansible/ansible-modules-extras on GitHub <http://github.com/ansible/ansible-modules-extras>`_
""" % (DEPRECATED, NOTCORE))
category_file.close() category_file.close()
# TODO: end a new category file # TODO: end a new category file

View file

@ -168,9 +168,11 @@ Notes
{% endfor %} {% endfor %}
{% endif %} {% endif %}
{% if not deprecated %} {% if not deprecated %}
{% if core %} Module Status: @{ ','.join(metadata.status) }@
--------------------
{% if metadata.supported_by == 'core' %}
This is a Core Module This is a Core Module
--------------------- ---------------------
@ -179,7 +181,7 @@ For more information on what this means please read :doc:`modules_core`
{% else %} {% else %}
This is an Extras Module This is module is supported by: @{ metadata.supported_by }@
------------------------ ------------------------
For more information on what this means please read :doc:`modules_extra` For more information on what this means please read :doc:`modules_extra`