mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2024-11-26 03:45:38 +01:00
Documentation improvements
Document that git is needed. Be clearer about the entry sort key being an entry sort key, not just a merge order. Be clearer about what "merge order" means. Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
This commit is contained in:
parent
8f46bbf46f
commit
28af958ea4
@ -5,6 +5,17 @@
|
|||||||
Add changelog entries to the first level-2 section.
|
Add changelog entries to the first level-2 section.
|
||||||
Create a new level-2 section for unreleased changes if needed.
|
Create a new level-2 section for unreleased changes if needed.
|
||||||
Remove the input files unless --keep-entries is specified.
|
Remove the input files unless --keep-entries is specified.
|
||||||
|
|
||||||
|
In each level-3 section, entries are sorted in chronological order
|
||||||
|
(oldest first). From oldest to newest:
|
||||||
|
* Merged entry files are sorted according to their merge date (date of
|
||||||
|
the merge commit that brought the commit that created the file into
|
||||||
|
the target branch).
|
||||||
|
* Committed but unmerged entry files are sorted according to the date
|
||||||
|
of the commit that adds them.
|
||||||
|
* Uncommitted entry files are sorted according to their modification time.
|
||||||
|
|
||||||
|
You must run this program from within a git working directory.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# Copyright (C) 2019, Arm Limited, All Rights Reserved
|
# Copyright (C) 2019, Arm Limited, All Rights Reserved
|
||||||
@ -224,11 +235,18 @@ class ChangeLog:
|
|||||||
|
|
||||||
|
|
||||||
@functools.total_ordering
|
@functools.total_ordering
|
||||||
class FileMergeTimestamp:
|
class EntryFileSortKey:
|
||||||
"""A timestamp indicating when a file was merged.
|
"""This classes defines an ordering on changelog entry files: older < newer.
|
||||||
|
|
||||||
If file1 was merged before file2, then
|
* Merged entry files are sorted according to their merge date (date of
|
||||||
FileMergeTimestamp(file1) <= FileMergeTimestamp(file2).
|
the merge commit that brought the commit that created the file into
|
||||||
|
the target branch).
|
||||||
|
* Committed but unmerged entry files are sorted according to the date
|
||||||
|
of the commit that adds them.
|
||||||
|
* Uncommitted entry files are sorted according to their modification time.
|
||||||
|
|
||||||
|
This class assumes that the file is in a git working directory with
|
||||||
|
the target branch checked out.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# Categories of files. A lower number is considered older.
|
# Categories of files. A lower number is considered older.
|
||||||
@ -301,7 +319,12 @@ class FileMergeTimestamp:
|
|||||||
return datetime.datetime.fromtimestamp(mtime)
|
return datetime.datetime.fromtimestamp(mtime)
|
||||||
|
|
||||||
def __init__(self, filename):
|
def __init__(self, filename):
|
||||||
"""Determine the timestamp at which the file was merged."""
|
"""Determine position of the file in the changelog entry order.
|
||||||
|
|
||||||
|
This constructor returns an object that can be used with comparison
|
||||||
|
operators, with `sort` and `sorted`, etc. Older entries are sorted
|
||||||
|
before newer entries.
|
||||||
|
"""
|
||||||
self.filename = filename
|
self.filename = filename
|
||||||
creation_hash = self.creation_hash(filename)
|
creation_hash = self.creation_hash(filename)
|
||||||
if not creation_hash:
|
if not creation_hash:
|
||||||
@ -317,10 +340,9 @@ class FileMergeTimestamp:
|
|||||||
self.datetime = self.commit_timestamp(merge_hash)
|
self.datetime = self.commit_timestamp(merge_hash)
|
||||||
|
|
||||||
def sort_key(self):
|
def sort_key(self):
|
||||||
""""Return a sort key for this merge timestamp object.
|
""""Return a concrete sort key for this entry file sort key object.
|
||||||
|
|
||||||
ts1.sort_key() < ts2.sort_key() if and only if ts1 is
|
``ts1 < ts2`` is implemented as ``ts1.sort_key() < ts2.sort_key()``.
|
||||||
considered to be older than ts2.
|
|
||||||
"""
|
"""
|
||||||
return (self.category, self.datetime, self.filename)
|
return (self.category, self.datetime, self.filename)
|
||||||
|
|
||||||
@ -375,11 +397,10 @@ def remove_merged_entries(files_to_remove):
|
|||||||
def list_files_to_merge(options):
|
def list_files_to_merge(options):
|
||||||
"""List the entry files to merge, oldest first.
|
"""List the entry files to merge, oldest first.
|
||||||
|
|
||||||
A file is considered older if it was merged earlier. See
|
"Oldest" is defined by `EntryFileSortKey`.
|
||||||
`FileMergeTimestamp` for details.
|
|
||||||
"""
|
"""
|
||||||
files_to_merge = glob.glob(os.path.join(options.dir, '*.md'))
|
files_to_merge = glob.glob(os.path.join(options.dir, '*.md'))
|
||||||
files_to_merge.sort(key=lambda f: FileMergeTimestamp(f).sort_key())
|
files_to_merge.sort(key=lambda f: EntryFileSortKey(f).sort_key())
|
||||||
return files_to_merge
|
return files_to_merge
|
||||||
|
|
||||||
def merge_entries(options):
|
def merge_entries(options):
|
||||||
@ -410,7 +431,7 @@ def show_file_timestamps(options):
|
|||||||
"""
|
"""
|
||||||
files = list_files_to_merge(options)
|
files = list_files_to_merge(options)
|
||||||
for filename in files:
|
for filename in files:
|
||||||
ts = FileMergeTimestamp(filename)
|
ts = EntryFileSortKey(filename)
|
||||||
print(ts.category, ts.datetime, filename)
|
print(ts.category, ts.datetime, filename)
|
||||||
|
|
||||||
def set_defaults(options):
|
def set_defaults(options):
|
||||||
|
Loading…
Reference in New Issue
Block a user