Compare commits
	
		
			21 Commits
		
	
	
		
			nilmdb-2.0
			...
			b6bba16505
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b6bba16505 | |||
| d4003d0d34 | |||
| 759492298a | |||
| b5f6fcc253 | |||
| 905e325ded | |||
| 648b6f4b70 | |||
| 7f8a2c7027 | |||
| 276fbc652a | |||
| 10b34f5937 | |||
| 83daeb148a | |||
| d65f00e8b2 | |||
| 71dc01c9a7 | |||
| bcd21b3498 | |||
| a1dee0e6f2 | |||
| 99ac47cf0d | |||
| 4cdaef51c1 | |||
| 88466dcafe | |||
| 8dfb8da15c | |||
| 6cc1f6b7b2 | |||
| 8dc36c2d37 | |||
| 3738430103 | 
| @@ -1,7 +1,7 @@ | ||||
| # nilmdb: Non-Intrusive Load Monitor Database | ||||
| by Jim Paris <jim@jtan.com> | ||||
|  | ||||
| NilmDB requires Python 3.7 or newer. | ||||
| NilmDB requires Python 3.8 or newer. | ||||
|  | ||||
| ## Prerequisites: | ||||
|  | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| #!/usr/bin/python | ||||
| #!/usr/bin/env python3 | ||||
|  | ||||
| import os | ||||
| import sys | ||||
|   | ||||
| @@ -145,8 +145,8 @@ class Client(): | ||||
|  | ||||
|         Example: | ||||
|           with client.stream_insert_context('/path', start, end) as ctx: | ||||
|             ctx.insert('1234567890.0 1 2 3 4\\n') | ||||
|             ctx.insert('1234567891.0 1 2 3 4\\n') | ||||
|             ctx.insert('1234567890000000 1 2 3 4\\n') | ||||
|             ctx.insert('1234567891000000 1 2 3 4\\n') | ||||
|  | ||||
|         For more details, see help for nilmdb.client.client.StreamInserter | ||||
|  | ||||
|   | ||||
| @@ -59,7 +59,7 @@ class NumpyClient(nilmdb.client.client.Client): | ||||
|         dtype = self._get_dtype(path, layout) | ||||
|  | ||||
|         def to_numpy(data): | ||||
|             a = numpy.fromstring(data, dtype) | ||||
|             a = numpy.frombuffer(data, dtype) | ||||
|             if structured: | ||||
|                 return a | ||||
|             return numpy.c_[a['timestamp'], a['data']] | ||||
|   | ||||
| @@ -66,7 +66,7 @@ class Complete(): | ||||
|         layouts = [] | ||||
|         for i in range(1, 10): | ||||
|             layouts.extend([(t + "_" + str(i)) for t in types]) | ||||
|         return (l for l in layouts if l.startswith(prefix)) | ||||
|         return (lay for lay in layouts if lay.startswith(prefix)) | ||||
|  | ||||
|     def meta_key(self, prefix, parsed_args, **kwargs): | ||||
|         return (kv.split('=')[0] for kv | ||||
|   | ||||
| @@ -1,7 +1,5 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
|  | ||||
| raise Exception("todo: fix path bytes issues") | ||||
|  | ||||
| """Check database consistency, with some ability to fix problems. | ||||
| This should be able to fix cases where a database gets corrupted due | ||||
| to unexpected system shutdown, and detect other cases that may cause | ||||
| @@ -13,7 +11,6 @@ import nilmdb.client.numpyclient | ||||
| from nilmdb.utils.interval import IntervalError | ||||
| from nilmdb.server.interval import Interval, IntervalSet | ||||
| from nilmdb.utils.printf import printf, fprintf, sprintf | ||||
| from nilmdb.utils.time import timestamp_to_string | ||||
|  | ||||
| from collections import defaultdict | ||||
| import sqlite3 | ||||
| @@ -21,70 +18,83 @@ import os | ||||
| import sys | ||||
| import progressbar | ||||
| import re | ||||
| import time | ||||
| import shutil | ||||
| import pickle | ||||
| import numpy | ||||
|  | ||||
|  | ||||
| class FsckError(Exception): | ||||
|     def __init__(self, msg = "", *args): | ||||
|     def __init__(self, msg="", *args): | ||||
|         if args: | ||||
|             msg = sprintf(msg, *args) | ||||
|         Exception.__init__(self, msg) | ||||
|  | ||||
|  | ||||
| class FixableFsckError(FsckError): | ||||
|     def __init__(self, msg = "", *args): | ||||
|         if args: | ||||
|             msg = sprintf(msg, *args) | ||||
|         FsckError.__init__(self, "%s\nThis may be fixable with \"--fix\".", msg) | ||||
|     def __init__(self, msg=""): | ||||
|         FsckError.__init__(self, f'{msg}\nThis may be fixable with "--fix".') | ||||
|  | ||||
|  | ||||
| class RetryFsck(FsckError): | ||||
|     pass | ||||
|  | ||||
|  | ||||
| class FsckFormatError(FsckError): | ||||
|     pass | ||||
|  | ||||
|  | ||||
| def log(format, *args): | ||||
|     printf(format, *args) | ||||
|  | ||||
|  | ||||
| def err(format, *args): | ||||
|     fprintf(sys.stderr, format, *args) | ||||
|  | ||||
|  | ||||
| # Decorator that retries a function if it returns a specific value | ||||
| def retry_if_raised(exc, message = None, max_retries = 100): | ||||
| def retry_if_raised(exc, message=None, max_retries=100): | ||||
|     def f1(func): | ||||
|         def f2(*args, **kwargs): | ||||
|             for n in range(max_retries): | ||||
|                 try: | ||||
|                     return func(*args, **kwargs) | ||||
|                 except exc as e: | ||||
|                 except exc: | ||||
|                     if message: | ||||
|                         log("%s\n\n", message) | ||||
|             raise Exception("Max number of retries (%d) exceeded; giving up") | ||||
|             raise Exception("Max number of retries (%d) exceeded; giving up" % | ||||
|                             max_retries) | ||||
|         return f2 | ||||
|     return f1 | ||||
|  | ||||
|  | ||||
| class Progress(object): | ||||
|     def __init__(self, maxval): | ||||
|         if maxval == 0: | ||||
|             maxval = 1 | ||||
|         self.bar = progressbar.ProgressBar( | ||||
|             maxval = maxval, | ||||
|             widgets = [ progressbar.Percentage(), ' ', | ||||
|                         progressbar.Bar(), ' ', | ||||
|                         progressbar.ETA() ]) | ||||
|         if self.bar.term_width == 0: | ||||
|             self.bar.term_width = 75 | ||||
|             maxval=maxval, | ||||
|             widgets=[progressbar.Percentage(), ' ', | ||||
|                      progressbar.Bar(), ' ', | ||||
|                      progressbar.ETA()]) | ||||
|         self.bar.term_width = self.bar.term_width or 75 | ||||
|  | ||||
|     def __enter__(self): | ||||
|         self.bar.start() | ||||
|         self.last_update = 0 | ||||
|         return self | ||||
|  | ||||
|     def __exit__(self, exc_type, exc_value, traceback): | ||||
|         if exc_type is None: | ||||
|             self.bar.finish() | ||||
|         else: | ||||
|             printf("\n") | ||||
|  | ||||
|     def update(self, val): | ||||
|         self.bar.update(val) | ||||
|  | ||||
| class Fsck(object): | ||||
|  | ||||
|     def __init__(self, path, fix = False): | ||||
| class Fsck(object): | ||||
|     def __init__(self, path, fix=False): | ||||
|         self.basepath = path | ||||
|         self.sqlpath = os.path.join(path, "data.sql") | ||||
|         self.bulkpath = os.path.join(path, "data") | ||||
| @@ -94,7 +104,7 @@ class Fsck(object): | ||||
|     ### Main checks | ||||
|  | ||||
|     @retry_if_raised(RetryFsck, "Something was fixed: restarting fsck") | ||||
|     def check(self, skip_data = False): | ||||
|     def check(self, skip_data=False): | ||||
|         self.bulk = None | ||||
|         self.sql = None | ||||
|         try: | ||||
| @@ -109,7 +119,9 @@ class Fsck(object): | ||||
|         finally: | ||||
|             if self.bulk: | ||||
|                 self.bulk.close() | ||||
|             if self.sql: | ||||
|             if self.sql:  # pragma: no cover | ||||
|                 # (coverage doesn't handle finally clauses correctly; | ||||
|                 # both branches here are tested) | ||||
|                 self.sql.commit() | ||||
|                 self.sql.close() | ||||
|         log("ok\n") | ||||
| @@ -164,7 +176,7 @@ class Fsck(object): | ||||
|                                  "ORDER BY start_time") | ||||
|             for r in result: | ||||
|                 if r[0] not in self.stream_path: | ||||
|                     raise FsckError("interval ID %d not in streams", k) | ||||
|                     raise FsckError("interval ID %d not in streams", r[0]) | ||||
|                 self.stream_interval[r[0]].append((r[1], r[2], r[3], r[4])) | ||||
|  | ||||
|             log("  loading metadata\n") | ||||
| @@ -172,10 +184,11 @@ class Fsck(object): | ||||
|             result = cur.execute("SELECT stream_id, key, value FROM metadata") | ||||
|             for r in result: | ||||
|                 if r[0] not in self.stream_path: | ||||
|                     raise FsckError("metadata ID %d not in streams", k) | ||||
|                     raise FsckError("metadata ID %d not in streams", r[0]) | ||||
|                 if r[1] in self.stream_meta[r[0]]: | ||||
|                     raise FsckError("duplicate metadata key '%s' for stream %d", | ||||
|                                     r[1], r[0]) | ||||
|                     raise FsckError( | ||||
|                         "duplicate metadata key '%s' for stream %d", | ||||
|                         r[1], r[0]) | ||||
|                 self.stream_meta[r[0]][r[1]] = r[2] | ||||
|  | ||||
|     ### Check streams and basic interval overlap | ||||
| @@ -202,6 +215,7 @@ class Fsck(object): | ||||
|  | ||||
|                 # must exist in bulkdata | ||||
|                 bulk = self.bulkpath + path | ||||
|                 bulk = bulk.encode('utf-8') | ||||
|                 if not os.path.isdir(bulk): | ||||
|                     raise FsckError("%s: missing bulkdata dir", path) | ||||
|                 if not nilmdb.server.bulkdata.Table.exists(bulk): | ||||
| @@ -228,36 +242,55 @@ class Fsck(object): | ||||
|                                             "set: %s\nnew: %s", | ||||
|                                             path, str(posiset), str(new)) | ||||
|  | ||||
|                 # check bulkdata | ||||
|                 self.check_bulkdata(sid, path, bulk) | ||||
|  | ||||
|                 # Check that we can open bulkdata | ||||
|                 try: | ||||
|                     tab = None | ||||
|                     try: | ||||
|                         tab = nilmdb.server.bulkdata.Table(bulk) | ||||
|                     except Exception as e: | ||||
|                         raise FsckError("%s: can't open bulkdata: %s", | ||||
|                                         path, str(e)) | ||||
|                 finally: | ||||
|                     if tab: | ||||
|                         tab.close() | ||||
|                     # Check bulkdata | ||||
|                     self.check_bulkdata(sid, path, bulk) | ||||
|  | ||||
|                     # Check that we can open bulkdata | ||||
|                     tab = nilmdb.server.bulkdata.Table(bulk) | ||||
|                 except FsckFormatError as e: | ||||
|                     # If there are no files except _format, try deleting | ||||
|                     # the entire stream; this may remove metadata, but | ||||
|                     # it's probably unimportant. | ||||
|                     files = list(os.listdir(bulk)) | ||||
|                     if len(files) > 1: | ||||
|                         raise FsckFormatError(f"{path}: can't load _format, " | ||||
|                                               f"but data is also present") | ||||
|  | ||||
|                     # Since the stream was empty, just remove it | ||||
|                     self.fix_remove_stream(sid, path, bulk, | ||||
|                                            "empty, with corrupted format file") | ||||
|                 except FsckError as e: | ||||
|                     raise e | ||||
|                 except Exception as e: # pragma: no cover | ||||
|                     # No coverage because this is an unknown/unexpected error | ||||
|                     raise FsckError("%s: can't open bulkdata: %s", | ||||
|                                     path, str(e)) | ||||
|                 tab.close() | ||||
|  | ||||
|     ### Check that bulkdata is good enough to be opened | ||||
|  | ||||
|     @retry_if_raised(RetryFsck) | ||||
|     def check_bulkdata(self, sid, path, bulk): | ||||
|         with open(os.path.join(bulk, "_format"), "rb") as f: | ||||
|             fmt = pickle.load(f) | ||||
|         try: | ||||
|             with open(os.path.join(bulk, b"_format"), "rb") as f: | ||||
|                 fmt = pickle.load(f) | ||||
|         except Exception as e: | ||||
|             raise FsckFormatError(f"{path}: can't load _format file ({e})") | ||||
|  | ||||
|         if fmt["version"] != 3: | ||||
|             raise FsckError("%s: bad or unsupported bulkdata version %d", | ||||
|                             path, fmt["version"]) | ||||
|         row_per_file = int(fmt["rows_per_file"]) | ||||
|             raise FsckFormatError("%s: bad or unsupported bulkdata version %d", | ||||
|                                   path, fmt["version"]) | ||||
|         rows_per_file = int(fmt["rows_per_file"]) | ||||
|         if rows_per_file < 1: | ||||
|             raise FsckFormatError(f"{path}: bad rows_per_file {rows_per_file}") | ||||
|         files_per_dir = int(fmt["files_per_dir"]) | ||||
|         if files_per_dir < 1: | ||||
|             raise FsckFormatError(f"{path}: bad files_per_dir {files_per_dir}") | ||||
|         layout = fmt["layout"] | ||||
|         if layout != self.stream_layout[sid]: | ||||
|             raise FsckError("%s: layout mismatch %s != %s", path, | ||||
|                             layout, self.stream_layout[sid]) | ||||
|             raise FsckFormatError("%s: layout mismatch %s != %s", path, | ||||
|                                   layout, self.stream_layout[sid]) | ||||
|  | ||||
|         # Every file should have a size that's the multiple of the row size | ||||
|         rkt = nilmdb.server.rocket.Rocket(layout, None) | ||||
| @@ -265,16 +298,16 @@ class Fsck(object): | ||||
|         rkt.close() | ||||
|  | ||||
|         # Find all directories | ||||
|         regex = re.compile("^[0-9a-f]{4,}$") | ||||
|         regex = re.compile(b"^[0-9a-f]{4,}$") | ||||
|         subdirs = sorted(filter(regex.search, os.listdir(bulk)), | ||||
|                          key = lambda x: int(x, 16), reverse = True) | ||||
|                          key=lambda x: int(x, 16), reverse=True) | ||||
|         for subdir in subdirs: | ||||
|             # Find all files in that dir | ||||
|             subpath = os.path.join(bulk, subdir) | ||||
|             files = list(filter(regex.search, os.listdir(subpath))) | ||||
|             if not files: | ||||
|                 self.fix_empty_subdir(subpath) | ||||
|                 raise RetryFsck | ||||
|  | ||||
|             # Verify that their size is a multiple of the row size | ||||
|             for filename in files: | ||||
|                 filepath = os.path.join(subpath, filename) | ||||
| @@ -290,10 +323,11 @@ class Fsck(object): | ||||
|         # as long as it's only ".removed" files. | ||||
|         err("\n%s\n", msg) | ||||
|         for fn in os.listdir(subpath): | ||||
|             if not fn.endswith(".removed"): | ||||
|             if not fn.endswith(b".removed"): | ||||
|                 raise FsckError("can't fix automatically: please manually " | ||||
|                                 "remove the file %s and try again", | ||||
|                                 os.path.join(subpath, fn)) | ||||
|                                 "remove the file '%s' and try again", | ||||
|                                 os.path.join(subpath, fn).decode( | ||||
|                                     'utf-8', errors='backslashreplace')) | ||||
|         # Remove the whole thing | ||||
|         err("Removing empty subpath\n") | ||||
|         shutil.rmtree(subpath) | ||||
| @@ -314,6 +348,24 @@ class Fsck(object): | ||||
|             f.truncate(newsize) | ||||
|             raise RetryFsck | ||||
|  | ||||
|     def fix_remove_stream(self, sid, path, bulk, reason): | ||||
|         msg = f"stream {path} is corrupted: {reason}" | ||||
|         if not self.fix: | ||||
|             raise FixableFsckError(msg) | ||||
|         # Remove the stream from disk and the database | ||||
|         err(f"\n{msg}\n") | ||||
|         err(f"Removing stream {path} from disk and database\n") | ||||
|         shutil.rmtree(bulk) | ||||
|         with self.sql: | ||||
|             cur = self.sql.cursor() | ||||
|             cur.execute("DELETE FROM streams WHERE id=?", | ||||
|                         (sid,)) | ||||
|             if cur.rowcount != 1:  # pragma: no cover (shouldn't fail) | ||||
|                 raise FsckError("failed to remove stream") | ||||
|             cur.execute("DELETE FROM ranges WHERE stream_id=?", (sid,)) | ||||
|             cur.execute("DELETE FROM metadata WHERE stream_id=?", (sid,)) | ||||
|         raise RetryFsck | ||||
|  | ||||
|     ### Check interval endpoints | ||||
|  | ||||
|     def check_intervals(self): | ||||
| @@ -324,9 +376,12 @@ class Fsck(object): | ||||
|             for sid in self.stream_interval: | ||||
|                 try: | ||||
|                     bulk = self.bulkpath + self.stream_path[sid] | ||||
|                     bulk = bulk.encode('utf-8') | ||||
|                     tab = nilmdb.server.bulkdata.Table(bulk) | ||||
|  | ||||
|                     def update(x): | ||||
|                         pbar.update(done + x) | ||||
|  | ||||
|                     ints = self.stream_interval[sid] | ||||
|                     done += self.check_table_intervals(sid, ints, tab, update) | ||||
|                 finally: | ||||
| @@ -335,7 +390,7 @@ class Fsck(object): | ||||
|     def check_table_intervals(self, sid, ints, tab, update): | ||||
|         # look in the table to make sure we can pick out the interval's | ||||
|         # endpoints | ||||
|         path = self.stream_path[sid] | ||||
|         path = self.stream_path[sid]  # noqa: F841 unused | ||||
|         tab.file_open.cache_remove_all() | ||||
|         for (i, intv) in enumerate(ints): | ||||
|             update(i) | ||||
| @@ -343,11 +398,11 @@ class Fsck(object): | ||||
|             if spos == epos and spos >= 0 and spos <= tab.nrows: | ||||
|                 continue | ||||
|             try: | ||||
|                 srow = tab[spos] | ||||
|                 erow = tab[epos-1] | ||||
|                 srow = tab[spos]    # noqa: F841 unused | ||||
|                 erow = tab[epos-1]  # noqa: F841 unused | ||||
|             except Exception as e: | ||||
|                 self.fix_bad_interval(sid, intv, tab, str(e)) | ||||
|                 raise RetryFsck | ||||
|  | ||||
|         return len(ints) | ||||
|  | ||||
|     def fix_bad_interval(self, sid, intv, tab, msg): | ||||
| @@ -376,23 +431,23 @@ class Fsck(object): | ||||
|                                 "end_time=? AND start_pos=? AND end_pos=?", | ||||
|                                 (new_etime, new_epos, sid, stime, etime, | ||||
|                                  spos, epos)) | ||||
|                     if cur.rowcount != 1: | ||||
|                     if cur.rowcount != 1:  # pragma: no cover (shouldn't fail) | ||||
|                         raise FsckError("failed to fix SQL database") | ||||
|                 raise RetryFsck | ||||
|             err("actually it can't be truncated; times are bad too") | ||||
|             err("actually it can't be truncated; times are bad too\n") | ||||
|  | ||||
|         # Otherwise, the only hope is to delete the interval entirely. | ||||
|         err("*** Deleting the entire interval from SQL.\n") | ||||
|         err("This may leave stale data on disk.  To fix that, copy all\n") | ||||
|         err("data from this stream to a new stream, then remove all data\n") | ||||
|         err("from and destroy %s.\n", path) | ||||
|         err("data from this stream to a new stream using nilm-copy, then\n") | ||||
|         err("remove all data from and destroy %s.\n", path) | ||||
|         with self.sql: | ||||
|             cur = self.sql.cursor() | ||||
|             cur.execute("DELETE FROM ranges WHERE " | ||||
|                         "stream_id=? AND start_time=? AND " | ||||
|                         "end_time=? AND start_pos=? AND end_pos=?", | ||||
|                         (sid, stime, etime, spos, epos)) | ||||
|             if cur.rowcount != 1: | ||||
|             if cur.rowcount != 1:  # pragma: no cover (shouldn't fail) | ||||
|                 raise FsckError("failed to remove interval") | ||||
|         raise RetryFsck | ||||
|  | ||||
| @@ -407,9 +462,12 @@ class Fsck(object): | ||||
|             for sid in self.stream_interval: | ||||
|                 try: | ||||
|                     bulk = self.bulkpath + self.stream_path[sid] | ||||
|                     bulk = bulk.encode('utf-8') | ||||
|                     tab = nilmdb.server.bulkdata.Table(bulk) | ||||
|  | ||||
|                     def update(x): | ||||
|                         pbar.update(done + x) | ||||
|  | ||||
|                     ints = self.stream_interval[sid] | ||||
|                     done += self.check_table_data(sid, ints, tab, update) | ||||
|                 finally: | ||||
| @@ -418,7 +476,7 @@ class Fsck(object): | ||||
|     def check_table_data(self, sid, ints, tab, update): | ||||
|         # Pull out all of the interval's data and verify that it's | ||||
|         # monotonic. | ||||
|         maxrows = 100000 | ||||
|         maxrows = getattr(self, 'maxrows_override', 100000) | ||||
|         path = self.stream_path[sid] | ||||
|         layout = self.stream_layout[sid] | ||||
|         dtype = nilmdb.client.numpyclient.layout_to_dtype(layout) | ||||
| @@ -438,27 +496,47 @@ class Fsck(object): | ||||
|  | ||||
|                 # Get raw data, convert to NumPy arary | ||||
|                 try: | ||||
|                     raw = tab.get_data(start, stop, binary = True) | ||||
|                     data = numpy.fromstring(raw, dtype) | ||||
|                 except Exception as e: | ||||
|                     raise FsckError("%s: failed to grab rows %d through %d: %s", | ||||
|                                     path, start, stop, repr(e)) | ||||
|                     raw = tab.get_data(start, stop, binary=True) | ||||
|                     data = numpy.frombuffer(raw, dtype) | ||||
|                 except Exception as e:  # pragma: no cover | ||||
|                     # No coverage because it's hard to trigger this -- earlier | ||||
|                     # checks check the ranges, so this would probably be a real | ||||
|                     # disk error, malloc failure, etc. | ||||
|                     raise FsckError( | ||||
|                         "%s: failed to grab rows %d through %d: %s", | ||||
|                         path, start, stop, repr(e)) | ||||
|  | ||||
|                 ts = data['timestamp'] | ||||
|  | ||||
|                 # Verify that all timestamps are in range. | ||||
|                 match = (ts < stime) | (ts >= etime) | ||||
|                 if match.any(): | ||||
|                     row = numpy.argmax(match) | ||||
|                     raise FsckError("%s: data timestamp %d at row %d " | ||||
|                                     "outside interval range [%d,%d)", | ||||
|                                     path, ts[row], row + start, | ||||
|                                     stime, etime) | ||||
|  | ||||
|                 # Verify that timestamps are monotonic | ||||
|                 if (numpy.diff(data['timestamp']) <= 0).any(): | ||||
|                     raise FsckError("%s: non-monotonic timestamp(s) in rows " | ||||
|                                     "%d through %d", path, start, stop) | ||||
|                 first_ts = data['timestamp'][0] | ||||
|                 match = numpy.diff(ts) <= 0 | ||||
|                 if match.any(): | ||||
|                     row = numpy.argmax(match) | ||||
|                     raise FsckError("%s: non-monotonic timestamp (%d -> %d)" | ||||
|                                     " at row %d", path, ts[row], ts[row+1], | ||||
|                                     row + start) | ||||
|  | ||||
|                 first_ts = ts[0] | ||||
|                 if last_ts is not None and first_ts <= last_ts: | ||||
|                     raise FsckError("%s: first interval timestamp %d is not " | ||||
|                                     "greater than the previous last interval " | ||||
|                                     "timestamp %d, at row %d", | ||||
|                                     path, first_ts, last_ts, start) | ||||
|                 last_ts = data['timestamp'][-1] | ||||
|                 last_ts = ts[-1] | ||||
|  | ||||
|                 # These are probably fixable, by removing the offending | ||||
|                 # intervals.  But I'm not going to bother implementing | ||||
|                 # that yet. | ||||
|                 # The previous errors are fixable, by removing the | ||||
|                 # offending intervals, or changing the data | ||||
|                 # timestamps.  But these are probably unlikely errors, | ||||
|                 # so it's not worth implementing that yet. | ||||
|  | ||||
|                 # Done | ||||
|                 done += count | ||||
|   | ||||
| @@ -1,27 +1,27 @@ | ||||
| #!/usr/bin/python | ||||
| #!/usr/bin/env python3 | ||||
|  | ||||
| import nilmdb.fsck | ||||
| import argparse | ||||
| import os | ||||
| import sys | ||||
|  | ||||
|  | ||||
| def main(): | ||||
|     """Main entry point for the 'nilmdb-fsck' command line script""" | ||||
|  | ||||
|     parser = argparse.ArgumentParser( | ||||
|         description = 'Check database consistency', | ||||
|         formatter_class = argparse.ArgumentDefaultsHelpFormatter) | ||||
|         description='Check database consistency', | ||||
|         formatter_class=argparse.ArgumentDefaultsHelpFormatter) | ||||
|     parser.add_argument("-v", "--version", action="version", | ||||
|                         version = nilmdb.__version__) | ||||
|                         version=nilmdb.__version__) | ||||
|     parser.add_argument("-f", "--fix", action="store_true", | ||||
|                         default=False, help = 'Fix errors when possible ' | ||||
|                         default=False, help='Fix errors when possible ' | ||||
|                         '(which may involve removing data)') | ||||
|     parser.add_argument("-n", "--no-data", action="store_true", | ||||
|                         default=False, help = 'Skip the slow full-data check') | ||||
|     parser.add_argument('database', help = 'Database directory') | ||||
|                         default=False, help='Skip the slow full-data check') | ||||
|     parser.add_argument('database', help='Database directory') | ||||
|     args = parser.parse_args() | ||||
|  | ||||
|     nilmdb.fsck.Fsck(args.database, args.fix).check(skip_data = args.no_data) | ||||
|     nilmdb.fsck.Fsck(args.database, args.fix).check(skip_data=args.no_data) | ||||
|  | ||||
|  | ||||
| if __name__ == "__main__": | ||||
|     main() | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| #!/usr/bin/python | ||||
| #!/usr/bin/env python3 | ||||
|  | ||||
| import os | ||||
| import sys | ||||
| @@ -78,9 +78,12 @@ def main(): | ||||
|                 stats = yappi.get_func_stats() | ||||
|                 stats.sort("ttot") | ||||
|                 stats.print_all() | ||||
|                 from IPython import embed | ||||
|                 embed(header="Use the `yappi` or `stats` object to explore " | ||||
|                       "further, quit to exit") | ||||
|                 try: | ||||
|                     from IPython import embed | ||||
|                     embed(header="Use the `yappi` or `stats` object to " | ||||
|                           "explore further, `quit` to exit") | ||||
|                 except ModuleNotFoundError: | ||||
|                     print("\nInstall ipython to explore further") | ||||
|         else: | ||||
|             server.start(blocking=True) | ||||
|     except nilmdb.server.serverutil.CherryPyExit: | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| #!/usr/bin/python | ||||
| #!/usr/bin/env python3 | ||||
|  | ||||
| import nilmdb.cmdline | ||||
|  | ||||
|   | ||||
| @@ -293,8 +293,8 @@ class Table(): | ||||
|             "layout": layout, | ||||
|             "version": 3 | ||||
|         } | ||||
|         with open(os.path.join(root, b"_format"), "wb") as f: | ||||
|             pickle.dump(fmt, f, 2) | ||||
|         nilmdb.utils.atomic.replace_file( | ||||
|             os.path.join(root, b"_format"), pickle.dumps(fmt, 2)) | ||||
|  | ||||
|     # Normal methods | ||||
|     def __init__(self, root, initial_nrows=0): | ||||
|   | ||||
| @@ -189,7 +189,7 @@ def cherrypy_patch_exit(): | ||||
|         if args.exc_type == CherryPyExit or args.exc_type == SystemExit: | ||||
|             return | ||||
|         sys.excepthook(args.exc_type, args.exc_value, | ||||
|                        args.exc_traceback) # pragma: no cover | ||||
|                        args.exc_traceback)  # pragma: no cover | ||||
|     threading.excepthook = hook | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -28,7 +28,7 @@ class Timestamper(): | ||||
|                 continue | ||||
|             # For some reason, coverage on python 3.8 reports that | ||||
|             # we never hit this break, even though we definitely do. | ||||
|             break # pragma: no cover | ||||
|             break  # pragma: no cover | ||||
|         try: | ||||
|             return next(self.ts_iter) + line | ||||
|         except StopIteration: | ||||
|   | ||||
| @@ -1,16 +1,41 @@ | ||||
| argcomplete>=1.10.0 | ||||
| CherryPy>=18.1.2 | ||||
| coverage>=4.5.4 | ||||
| cython>=0.29.13 | ||||
| decorator>=4.4.0 | ||||
| fallocate>=1.6.4 | ||||
| flake8>=3.7.8 | ||||
| nose>=1.3.7 | ||||
| numpy>=1.17.0 | ||||
| progressbar>=2.5 | ||||
| psutil>=5.6.3 | ||||
| python-datetime-tz>=0.5.4 | ||||
| python-dateutil>=2.8.0 | ||||
| requests>=2.22.0 | ||||
| tz>=0.2.2 | ||||
| WebTest>=2.0.33 | ||||
| argcomplete==1.12.0 | ||||
| CherryPy==18.6.0 | ||||
| coverage==5.2.1 | ||||
| Cython==0.29.21 | ||||
| decorator==4.4.2 | ||||
| fallocate==1.6.4 | ||||
| flake8==3.8.3 | ||||
| nose==1.3.7 | ||||
| numpy==1.19.1 | ||||
| progressbar==2.5 | ||||
| psutil==5.7.2 | ||||
| python-datetime-tz==0.5.4 | ||||
| python-dateutil==2.8.1 | ||||
| requests==2.24.0 | ||||
| tz==0.2.2 | ||||
| yappi==1.2.5 | ||||
|  | ||||
| ## The following requirements were added by pip freeze: | ||||
| beautifulsoup4==4.9.1 | ||||
| certifi==2020.6.20 | ||||
| chardet==3.0.4 | ||||
| cheroot==8.4.2 | ||||
| idna==2.10 | ||||
| jaraco.classes==3.1.0 | ||||
| jaraco.collections==3.0.0 | ||||
| jaraco.functools==3.0.1 | ||||
| jaraco.text==3.2.0 | ||||
| mccabe==0.6.1 | ||||
| more-itertools==8.4.0 | ||||
| portend==2.6 | ||||
| pycodestyle==2.6.0 | ||||
| pyflakes==2.2.0 | ||||
| pytz==2020.1 | ||||
| six==1.15.0 | ||||
| soupsieve==2.0.1 | ||||
| tempora==4.0.0 | ||||
| urllib3==1.25.10 | ||||
| waitress==1.4.4 | ||||
| WebOb==1.8.6 | ||||
| WebTest==2.0.35 | ||||
| zc.lockfile==2.0 | ||||
|   | ||||
| @@ -47,10 +47,13 @@ tag_prefix=nilmdb- | ||||
| parentdir_prefix=nilmdb- | ||||
|  | ||||
| [flake8] | ||||
| exclude=_version.py,fsck.py,nilmdb_fsck.py | ||||
| exclude=_version.py | ||||
| extend-ignore=E731 | ||||
| per-file-ignores=__init__.py:F401,E402 serializer.py:E722 mustclose.py:E722 | ||||
| per-file-ignores=__init__.py:F401,E402 \ | ||||
|         serializer.py:E722 \ | ||||
|         mustclose.py:E722 \ | ||||
|         fsck.py:E266 | ||||
|  | ||||
| [pylint] | ||||
| ignore=_version.py,fsck.py,nilmdb_fsck.py | ||||
| ignore=_version.py | ||||
| disable=C0103,C0111,R0913,R0914 | ||||
|   | ||||
							
								
								
									
										2
									
								
								setup.py
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								setup.py
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| #!/usr/bin/python | ||||
| #!/usr/bin/env python3 | ||||
|  | ||||
| # To release a new version, tag it: | ||||
| #   git tag -a nilmdb-1.1 -m "Version 1.1" | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test1/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test1/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1
									
								
								tests/fsck-data/test1/data/git-empty-dir-placeholder
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								tests/fsck-data/test1/data/git-empty-dir-placeholder
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| hi | ||||
							
								
								
									
										1
									
								
								tests/fsck-data/test1a/data/git-empty-dir-placeholder
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								tests/fsck-data/test1a/data/git-empty-dir-placeholder
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| hi | ||||
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test1b/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test1b/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test1c/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test1c/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1
									
								
								tests/fsck-data/test1c/data/git-empty-dir-placeholder
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								tests/fsck-data/test1c/data/git-empty-dir-placeholder
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| hi | ||||
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2a/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2a/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2a/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2a/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2a/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2a/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2b/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2b/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2b/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2b/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2b/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2b/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2c/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2c/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2c/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2c/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2c/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2c/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2d/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2d/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2d/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2d/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2d/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2d/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2e/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2e/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2e/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2e/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2e/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2e/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2f/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2f/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2f/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2f/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2f/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2f/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2g/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2g/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2g/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2g/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2g/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2g/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2h/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2h/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1
									
								
								tests/fsck-data/test2h/data/git-empty-dir-placeholder
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								tests/fsck-data/test2h/data/git-empty-dir-placeholder
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| hi | ||||
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2i/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2i/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2i/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2i/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2j/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2j/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2j/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2j/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2j/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2j/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2k/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2k/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2k/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2k/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2k/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2k/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2k1/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2k1/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2k1/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2k1/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2k1/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2k1/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2l/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2l/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2l/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2l/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2l/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2l/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2m/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2m/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2m/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2m/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2m/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2m/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2n/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2n/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2n/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2n/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2n/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2n/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2o/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2o/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2o/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2o/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2o/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2o/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -0,0 +1 @@ | ||||
| hi | ||||
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p1/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p1/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p1/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p1/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1
									
								
								tests/fsck-data/test2p1/data/a/b/0001/hello
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								tests/fsck-data/test2p1/data/a/b/0001/hello
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| world | ||||
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p1/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p1/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p2/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p2/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p2/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p2/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1
									
								
								tests/fsck-data/test2p2/data/a/b/0001/hello.removed
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								tests/fsck-data/test2p2/data/a/b/0001/hello.removed
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| world | ||||
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2p2/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2p2/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data/a/c/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data/a/c/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data/a/c/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2q/data/a/c/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r1/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r1/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r1/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r1/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r1/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r1/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r2/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r2/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r2/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r2/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2r2/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2r2/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2s/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2s/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2s/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2s/data/a/b/0000/0000
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2s/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2s/data/a/b/_format
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/fsck-data/test2t/data.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/fsck-data/test2t/data.sql
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user