+def convert_str(s):
+ if s == "None":
+ return None
+ else:
+ return int(float(s))
+
+
+dump_file = open(sys.argv[1], 'r',
+ encoding=xsetbg_conf.get("images", "fs_encoding"))
+xsetbg_db = recreate_db()
+count_new = count_old = count_updated = 0
+
+with SQLiteMassInsert() as txn:
+ for line in dump_file:
+ id, timestamp, filename = line.strip().split(None, 2)
+ id = convert_str(id)
+ timestamp = convert_str(timestamp)
+ try:
+ if id:
+ row = xsetbg_db.get(id)
+ else:
+ row = xsetbg_db.byFull_name(filename)
+ except SQLObjectNotFound:
+ values = {'last_shown': timestamp,
+ 'full_name': filename.encode('utf-8')}
+ if id:
+ values['id'] = id
+ query = txn.sqlrepr(Insert(xsetbg_db.sqlmeta.table, values=values))
+ txn.query(query)
+ count_new += 1
+ else:
+ assert id is None or row.id == id
+ if row.last_shown is not None:
+ assert row.last_shown == timestamp
+ if row.full_name == filename:
+ count_old += 1
+ else:
+ row.full_name = filename
+ count_updated += 1