# HG changeset patch # User Pierre-Yves David # Date 1623260849 -7200 # Node ID f93a867a6486b52074f73e32354108ebf40f05f7 # Parent 865c260d7163a604a54b96159351f3c7edb06b85 revlog: list older-but-still-around file in `files` These older files will eventually be removed, but we have to take them in account until they are. So we update `files` to keep fncache happy. Differential Revision: https://phab.mercurial-scm.org/D10868 diff -r 865c260d7163 -r f93a867a6486 mercurial/revlog.py --- a/mercurial/revlog.py Sat May 29 00:11:12 2021 +0200 +++ b/mercurial/revlog.py Wed Jun 09 19:47:29 2021 +0200 @@ -2821,10 +2821,13 @@ res.append(self._datafile) else: res.append(self._docket_file) + res.extend(self._docket.old_index_filepaths(include_empty=False)) if self._docket.data_end: res.append(self._datafile) + res.extend(self._docket.old_data_filepaths(include_empty=False)) if self._docket.sidedata_end: res.append(self._sidedatafile) + res.extend(self._docket.old_sidedata_filepaths(include_empty=False)) return res def emitrevisions( diff -r 865c260d7163 -r f93a867a6486 mercurial/revlogutils/docket.py --- a/mercurial/revlogutils/docket.py Sat May 29 00:11:12 2021 +0200 +++ b/mercurial/revlogutils/docket.py Wed Jun 09 19:47:29 2021 +0200 @@ -182,6 +182,13 @@ self._index_uuid = make_uid() return self.index_filepath() + def old_index_filepaths(self, include_empty=True): + """yield file path to older index files associated to this docket""" + # very simplistic version at first + for uuid, size in self._older_index_uuids: + if include_empty or size > 0: + yield b"%s-%s.idx" % (self._radix, uuid) + def data_filepath(self): """file path to the current data file associated to this docket""" # very simplistic version at first @@ -198,6 +205,13 @@ self._data_uuid = make_uid() return self.data_filepath() + def old_data_filepaths(self, include_empty=True): + """yield file path to older data files associated to this docket""" + # very simplistic version at first + for uuid, size in self._older_data_uuids: + if include_empty or size > 0: + yield b"%s-%s.dat" % (self._radix, uuid) + def sidedata_filepath(self): """file path to the current sidedata file associated to this docket""" # very simplistic version at first @@ -214,6 +228,13 @@ self._sidedata_uuid = make_uid() return self.sidedata_filepath() + def old_sidedata_filepaths(self, include_empty=True): + """yield file path to older sidedata files associated to this docket""" + # very simplistic version at first + for uuid, size in self._older_sidedata_uuids: + if include_empty or size > 0: + yield b"%s-%s.sda" % (self._radix, uuid) + @property def index_end(self): return self._index_end