Windev Today
log.append( "time": self.timestamp(), "original": original, "backup": backup, "hash": hashlib.md5(open(original, 'rb').read()).hexdigest() )
print(f"[Windev] Backed up: filepath → backup_path") windev
def backup_file(self, filepath): # Create relative path to maintain folder structure rel_path = os.path.relpath(filepath, WATCH_DIR) backup_path = os.path.join(BACKUP_DIR, rel_path + f".self.timestamp().bak") os.makedirs(os.path.dirname(backup_path), exist_ok=True) log.append( "time": self.timestamp()
# Log change self.log_change(filepath, backup_path) WATCH_DIR) backup_path = os.path.join(BACKUP_DIR
with open(LOG_FILE, 'w') as f: json.dump(log, f, indent=2)
def log_change(self, original, backup): log = [] if os.path.exists(LOG_FILE): with open(LOG_FILE, 'r') as f: log = json.load(f)
# Copy file with metadata shutil.copy2(filepath, backup_path)