1
0
mirror of https://github.com/moparisthebest/xeps synced 2024-11-21 08:45:04 -05:00

tools: Implement modification of XEPs in deferrals.py

This commit is contained in:
Jonas Wielicki 2017-09-11 17:40:47 +02:00
parent be7cb4dee6
commit 0fe90cc291
3 changed files with 92 additions and 6 deletions

View File

@ -1,4 +1,6 @@
#!/usr/bin/env python3 #!/usr/bin/env python3
import re
import xml.etree.ElementTree as etree import xml.etree.ElementTree as etree
from datetime import datetime, timedelta from datetime import datetime, timedelta
@ -17,6 +19,51 @@ def get_deferred(accepted):
yield info yield info
EXPERIMENTAL_STATUS = "<status>Experimental</status>"
DEFERRED_STATUS = "<status>Deferred</status>"
REVISION_RE = re.compile(r"\s+<revision>")
REVISION_TEMPLATE = """
<revision>
<version>{version}</version>
<date>{now:%Y-%m-%d}</date>
<initials>XEP Editor ({initials})</initials>
<remark>Defer due to lack of activity.</remark>
</revision>"""
def defer_xep(number, last_version, initials):
filename = "xep-{:04d}.xml".format(number)
with open(filename, "r") as f:
xep_text = f.read()
if EXPERIMENTAL_STATUS not in xep_text:
raise ValueError("cannot find experimental status in XEP text")
# this is so incredibly evil ...
xep_text = xep_text.replace(EXPERIMENTAL_STATUS, DEFERRED_STATUS, 1)
revision_match = REVISION_RE.search(xep_text)
version = last_version.split(".")
if len(version) == 1:
version.append("1")
else:
version[1] = str(int(version[1]) + 1)
del version[2:]
xep_text = (
xep_text[:revision_match.start()] +
REVISION_TEMPLATE.format(
now=datetime.utcnow(),
version=".".join(version),
initials=initials,
) + xep_text[revision_match.start():]
)
with open(filename, "w") as f:
f.write(xep_text)
f.flush()
def main(): def main():
import argparse import argparse
@ -32,10 +79,18 @@ def main():
) )
parser.add_argument( parser.add_argument(
"-m", "--modify", "-v", "--verbose",
help="Print additional metadata for deferred XEPs",
action="store_true", action="store_true",
default=False, default=False,
help="Modify the XEP files in-place." )
parser.add_argument(
"-m", "--modify",
default=False,
metavar="INITIALS",
help="Modify the to-be-deferred XEPs in-place and use the given "
"INITIALS in the remarks."
) )
args = parser.parse_args() args = parser.parse_args()
@ -50,7 +105,20 @@ def main():
deferred = list(get_deferred(accepted)) deferred = list(get_deferred(accepted))
for deferred_info in deferred: for deferred_info in deferred:
print(deferred_info["number"]) if args.modify:
defer_xep(deferred_info["number"],
deferred_info["last_revision"]["version"],
args.modify)
if args.verbose:
print(
"XEP-{info[number]:04d}: {info[title]} "
"(last update {info[last_revision][date]:%Y-%m-%d})".format(
info=deferred_info
)
)
else:
print(deferred_info["number"])
if __name__ == "__main__": if __name__ == "__main__":

View File

@ -68,6 +68,19 @@ Changelog:
URL: {url}""" URL: {url}"""
MAIL_DEFER_TEMPLATE = """\
XEP-{info[number]:04d} ({info[title]}) has been Deferred because of inactivity.
Abstract:
{info[abstract]}
URL: {url}
If and when a new revision of this XEP is published, its status will be \
changed back to Experimental.
"""
SUBJECT_NONPROTO_TEMPLATE = \ SUBJECT_NONPROTO_TEMPLATE = \
"{action.value}: XEP-{info[number]:04d} ({info[title]})" "{action.value}: XEP-{info[number]:04d} ({info[title]})"
@ -152,6 +165,10 @@ def make_nonproto_mail(action, info):
), ),
} }
body_template = MAIL_NONPROTO_TEMPLATE
if action == Action.DEFER:
body_template = MAIL_DEFER_TEMPLATE
mail = email.message.EmailMessage() mail = email.message.EmailMessage()
mail["Subject"] = SUBJECT_NONPROTO_TEMPLATE.format(**kwargs) mail["Subject"] = SUBJECT_NONPROTO_TEMPLATE.format(**kwargs)
mail["XSF-XEP-Action"] = action.value mail["XSF-XEP-Action"] = action.value
@ -161,7 +178,7 @@ def make_nonproto_mail(action, info):
mail["XSF-XEP-Number"] = "{:04d}".format(info["number"]) mail["XSF-XEP-Number"] = "{:04d}".format(info["number"])
mail["XSF-XEP-Url"] = kwargs["url"] mail["XSF-XEP-Url"] = kwargs["url"]
mail.set_content( mail.set_content(
wraptext(MAIL_NONPROTO_TEMPLATE.format(**kwargs)), wraptext(body_template.format(**kwargs)),
"plain", "plain",
"utf-8", "utf-8",
) )

View File

@ -35,6 +35,7 @@ class Action(enum.Enum):
OBSOLETE = "OBSOLETED" OBSOLETE = "OBSOLETED"
DEFER = "DEFERRED" DEFER = "DEFERRED"
UPDATE = "UPDATED" UPDATE = "UPDATED"
DEPRECATE = "DEPRECATED"
@classmethod @classmethod
def fromstatus(cls, status): def fromstatus(cls, status):
@ -44,9 +45,9 @@ class Action(enum.Enum):
Status.ACTIVE: cls.ACTIVE, Status.ACTIVE: cls.ACTIVE,
Status.FINAL: cls.FINAL, Status.FINAL: cls.FINAL,
Status.RETRACTED: cls.RETRACT, Status.RETRACTED: cls.RETRACT,
Status.OBSOLETED: cls.OBSOLETE, Status.OBSOLETE: cls.OBSOLETE,
Status.DEPRECATED: cls.DEPRECATE, Status.DEPRECATED: cls.DEPRECATE,
Status.DEFERRED: cls.DEFERRED, Status.DEFERRED: cls.DEFER,
}[status] }[status]