mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-03 15:17:25 +00:00
cmd/stindex: Add missing KeyType values in stindex dump code (#6659)
* cmd/stindex: Unify access to key from cached variable. Avoid calling the Key() method from the iterator each time the value is needed. Just reuse the cache variable already assigned before the switch block. * cmd/stindex: Display the prefix byte value for unknown key types. Make it easier to diagnose corrupt / unknown key type entries by showing their decimal value, correlating with the definitions in keyer.go. * cmd/stindex: Add missing KeyType values in stindex dump code. Recently added DB key prefixes KeyTypeBlockListMap and KeyTypeVersion were unknown to the stindex dumping tool. Add basic parsing to dump their key structure.
This commit is contained in:
parent
5ffa012410
commit
668979605b
@ -52,10 +52,10 @@ func dump(ldb backend.Backend) {
|
|||||||
fmt.Printf("[block] F:%d H:%x N:%q I:%d\n", folder, hash, name, binary.BigEndian.Uint32(it.Value()))
|
fmt.Printf("[block] F:%d H:%x N:%q I:%d\n", folder, hash, name, binary.BigEndian.Uint32(it.Value()))
|
||||||
|
|
||||||
case db.KeyTypeDeviceStatistic:
|
case db.KeyTypeDeviceStatistic:
|
||||||
fmt.Printf("[dstat] K:%x V:%x\n", it.Key(), it.Value())
|
fmt.Printf("[dstat] K:%x V:%x\n", key, it.Value())
|
||||||
|
|
||||||
case db.KeyTypeFolderStatistic:
|
case db.KeyTypeFolderStatistic:
|
||||||
fmt.Printf("[fstat] K:%x V:%x\n", it.Key(), it.Value())
|
fmt.Printf("[fstat] K:%x V:%x\n", key, it.Value())
|
||||||
|
|
||||||
case db.KeyTypeVirtualMtime:
|
case db.KeyTypeVirtualMtime:
|
||||||
folder := binary.BigEndian.Uint32(key[1:])
|
folder := binary.BigEndian.Uint32(key[1:])
|
||||||
@ -67,11 +67,11 @@ func dump(ldb backend.Backend) {
|
|||||||
fmt.Printf("[mtime] F:%d N:%q R:%v V:%v\n", folder, name, real, virt)
|
fmt.Printf("[mtime] F:%d N:%q R:%v V:%v\n", folder, name, real, virt)
|
||||||
|
|
||||||
case db.KeyTypeFolderIdx:
|
case db.KeyTypeFolderIdx:
|
||||||
key := binary.BigEndian.Uint32(it.Key()[1:])
|
key := binary.BigEndian.Uint32(key[1:])
|
||||||
fmt.Printf("[folderidx] K:%d V:%q\n", key, it.Value())
|
fmt.Printf("[folderidx] K:%d V:%q\n", key, it.Value())
|
||||||
|
|
||||||
case db.KeyTypeDeviceIdx:
|
case db.KeyTypeDeviceIdx:
|
||||||
key := binary.BigEndian.Uint32(it.Key()[1:])
|
key := binary.BigEndian.Uint32(key[1:])
|
||||||
val := it.Value()
|
val := it.Value()
|
||||||
if len(val) == 0 {
|
if len(val) == 0 {
|
||||||
fmt.Printf("[deviceidx] K:%d V:<nil>\n", key)
|
fmt.Printf("[deviceidx] K:%d V:<nil>\n", key)
|
||||||
@ -81,32 +81,41 @@ func dump(ldb backend.Backend) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
case db.KeyTypeIndexID:
|
case db.KeyTypeIndexID:
|
||||||
device := binary.BigEndian.Uint32(it.Key()[1:])
|
device := binary.BigEndian.Uint32(key[1:])
|
||||||
folder := binary.BigEndian.Uint32(it.Key()[5:])
|
folder := binary.BigEndian.Uint32(key[5:])
|
||||||
fmt.Printf("[indexid] D:%d F:%d I:%x\n", device, folder, it.Value())
|
fmt.Printf("[indexid] D:%d F:%d I:%x\n", device, folder, it.Value())
|
||||||
|
|
||||||
case db.KeyTypeFolderMeta:
|
case db.KeyTypeFolderMeta:
|
||||||
folder := binary.BigEndian.Uint32(it.Key()[1:])
|
folder := binary.BigEndian.Uint32(key[1:])
|
||||||
fmt.Printf("[foldermeta] F:%d V:%x\n", folder, it.Value())
|
fmt.Printf("[foldermeta] F:%d V:%x\n", folder, it.Value())
|
||||||
|
|
||||||
case db.KeyTypeMiscData:
|
case db.KeyTypeMiscData:
|
||||||
fmt.Printf("[miscdata] K:%q V:%q\n", it.Key()[1:], it.Value())
|
fmt.Printf("[miscdata] K:%q V:%q\n", key[1:], it.Value())
|
||||||
|
|
||||||
case db.KeyTypeSequence:
|
case db.KeyTypeSequence:
|
||||||
folder := binary.BigEndian.Uint32(it.Key()[1:])
|
folder := binary.BigEndian.Uint32(key[1:])
|
||||||
seq := binary.BigEndian.Uint64(it.Key()[5:])
|
seq := binary.BigEndian.Uint64(key[5:])
|
||||||
fmt.Printf("[sequence] F:%d S:%d V:%q\n", folder, seq, it.Value())
|
fmt.Printf("[sequence] F:%d S:%d V:%q\n", folder, seq, it.Value())
|
||||||
|
|
||||||
case db.KeyTypeNeed:
|
case db.KeyTypeNeed:
|
||||||
folder := binary.BigEndian.Uint32(it.Key()[1:])
|
folder := binary.BigEndian.Uint32(key[1:])
|
||||||
file := string(it.Key()[5:])
|
file := string(key[5:])
|
||||||
fmt.Printf("[need] F:%d V:%q\n", folder, file)
|
fmt.Printf("[need] F:%d V:%q\n", folder, file)
|
||||||
|
|
||||||
case db.KeyTypeBlockList:
|
case db.KeyTypeBlockList:
|
||||||
fmt.Printf("[blocklist] H:%x\n", it.Key()[1:])
|
fmt.Printf("[blocklist] H:%x\n", key[1:])
|
||||||
|
|
||||||
|
case db.KeyTypeBlockListMap:
|
||||||
|
folder := binary.BigEndian.Uint32(key[1:])
|
||||||
|
hash := key[5:37]
|
||||||
|
fileName := string(key[37:])
|
||||||
|
fmt.Printf("[blocklistmap] F:%d H:%x N:%s\n", folder, hash, fileName)
|
||||||
|
|
||||||
|
case db.KeyTypeVersion:
|
||||||
|
fmt.Printf("[version] H:%x\n", key[1:])
|
||||||
|
|
||||||
default:
|
default:
|
||||||
fmt.Printf("[???]\n %x\n %x\n", it.Key(), it.Value())
|
fmt.Printf("[??? %d]\n %x\n %x\n", key[0], key, it.Value())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user