Sort Options and Outputs in API.txt

Python does not guarantee dict order. Our reliance on it in `makeapi`
is technically incorrect, even if it doesn't matter yet in any of our
developers' environments.
This patch sorts the options by name instead of relying on dict order.

As an added benefit, future API.txt diffs should be be neater.
This commit is contained in:
Petr Viktorin
2012-04-12 08:39:39 -04:00
committed by Martin Kosek
parent 7f27a18b51
commit fa6be6d8db
2 changed files with 1349 additions and 1348 deletions

2692
API.txt

File diff suppressed because it is too large Load Diff

View File

@@ -27,6 +27,7 @@ import sys
import os import os
import re import re
import inspect import inspect
import operator
from ipalib import api from ipalib import api
from ipalib.parameters import Param from ipalib.parameters import Param
from ipalib.output import Output from ipalib.output import Output
@@ -206,9 +207,9 @@ def make_api():
fd.write('args: %d,%d,%d\n' % (len(cmd.args), len(cmd.options), len(cmd.output))) fd.write('args: %d,%d,%d\n' % (len(cmd.args), len(cmd.options), len(cmd.output)))
for a in cmd.args(): for a in cmd.args():
fd.write('arg: %s\n' % param_repr(a)) fd.write('arg: %s\n' % param_repr(a))
for o in cmd.options(): for o in sorted(cmd.options(), key=operator.attrgetter('name')):
fd.write('option: %s\n' % param_repr(o)) fd.write('option: %s\n' % param_repr(o))
for o in cmd.output(): for o in sorted(cmd.output(), key=operator.attrgetter('name')):
fd.write('output: %s\n' % param_repr(o)) fd.write('output: %s\n' % param_repr(o))
fd.close() fd.close()