Print more info about devices
Details
- Reviewers
bruns - Group Reviewers
Baloo Frameworks - Maniphest Tasks
- T8250: Sanitize the database
- Commits
- R293:07601590347f: sanitizer: Improve device listing
Example:
$ baloodb devices Listing database contents... ! device:41 indexed-items:40 + device:43 indexed-items:76 fstype:cifs fsname://circulans/VideoPartition mount:/media/circulans/videopart + device:42 indexed-items:3627 fstype:fusectl fsname:fusectl mount:/sys/fs/fuse/connections + device:22 indexed-items:3 fstype:tmpfs fsname:tmpfs mount:/run ! device:2098 indexed-items:1450 ! device:2086 indexed-items:220 ! device:2069 indexed-items:1533 ! device:2064 indexed-items:99 ! device:2066 indexed-items:11664 + device:2053 indexed-items:6369 fstype:ext4 fsname:/dev/sda5 mount:/home + device:2049 indexed-items:22 fstype:ext4 fsname:/dev/sda1 mount:/ Found 11 matching items Elapsed: 7.26369 secs
Diff Detail
- Repository
- R293 Baloo
- Branch
- sanitize-devices (branched from master)
- Lint
No Linters Available - Unit
No Unit Test Coverage
Could you please make your tab spacing conform to the style of the
codebase? This should also be fixed in baloodb.
baloo follows Kdelibs Coding Style that is 4 spaces per tab. Please specify the places this code (or baloodb) deviates from the rules.
If you browse your recently committed code in Diffusion, you'll notice that your linespaces can be copy and pasted. This doesn't match the current style where the tabs are spaces and the linespaces don't contain tab spaces and thus won't be copyable.
baloo follows Kdelibs Coding Style that is 4 spaces per tab. Please specify the places this code (or baloodb) deviates from the rules.
src/engine/databasesanitizer.cpp | ||
---|---|---|
251 | You can check if your output goes to a tty or is redirected: | |
253 | print as hex(major):hex(minor) ? | |
src/engine/fsutils.cpp | ||
111 | Use of Solid would be preferred. | |
src/engine/fsutils.h | ||
51 | No need for explicitly calling the default constructor, this is only needed for POD types (e.g. quint64). |
src/engine/databasesanitizer.cpp | ||
---|---|---|
251 | That's great, thank you. I'll add some color to stdout in another patch. | |
253 | Good idea was my first thought, but after trying, I must say it does not add really much info and makes the output harder to read. | |
src/engine/fsutils.cpp | ||
111 | Sure? We would have to add Solid as a dependency for libKF5BalooEngine.so. The true reason for 'fsutils`'s existence is to disable CoW on btrfs. Can Solid do that? If so we can drop fsutils. |
src/engine/databasesanitizer.cpp | ||
---|---|---|
251 | Hey, that's an IIFE! Never seen it in C++ before. |
src/engine/databasesanitizer.cpp | ||
---|---|---|
158 ↗ | (On Diff #30514) | I can not come up with a reason to use a MultiHash here in the first place - all that is needed is the deviceId and the file count per device. You can use a QMap<DeviceId, Count> here, and use usedDevices[info.deviceId] += 1; (operator[] default-constructs the ValueType, which for e.g. int is guranteed by Qt to be 0). This reduces the effort for counting the items per device from (D + 3) * F to F. In your case, this would reduce the time for counting by a factor of 14. You also save the memory for creating a temporary MultiHash with ~20000 items. |
src/engine/fsutils.cpp | ||
111 | The question is if this really belongs in the library then. IMHO the whole printDevices() function should be moved into baloodb.cpp, The DatabaseSanitizer should export either createList or a function returning QVector<DeviceId, Count>. Going from the DeviceId to the DeviceInfo should happen in baloodb. |
src/engine/databasesanitizer.cpp | ||
---|---|---|
158 ↗ | (On Diff #30514) | Thanks! |
src/engine/fsutils.cpp | ||
111 | I agree completely and followed your suggestion. Currently I'm stuck, though. |
src/engine/fsutils.cpp | ||
---|---|---|
111 | While implementing your "I can not come up with a reason ..." suggestion, I realized, the 'clean' command also needs DeviceInfo to exclude unmounted devices. |
src/engine/fsutils.cpp | ||
---|---|---|
111 | Which is good, as the device id is completely bogus, and changes dependent on mount order. Also the inode is not generally stable for at least smb, as not every server supports inodes exported from the server, and can not when several server filesystems are exported as a single share. baloo on network shares will likely never work. |
src/engine/databasesanitizer.cpp | ||
---|---|---|
165 ↗ | (On Diff #30514) | Will try to use QStorageInfo |
src/engine/databasesanitizer.cpp | ||
---|---|---|
163 ↗ | (On Diff #30514) | instead of checking and filling it in here, just iterate over usedDevices after you have finished iterating over infos. |
- (Prematurely) rebased on origin/master From now on -DBUILD_EXPERIMENTAL=on is needed to build
- Remove unnecessary includes
I'm afraid you guys' code writing abilities have far surpassed my code review abilities at this point!
Arrgh these deviceIds! Just realized this:
When logged in as root on tty1
$ baloodb devices Listing database contents... + device:43 indexed-items:3658 fstype:tmpfs fsname:tmpfs mount:/run/user/0 + device:2049 indexed-items:2 fstype:ext4 fsname:/dev/sda1 mount:/
After logging out from tty1 and re-mounting smb share:
$ baloodb devices Listing database contents... + device:43 indexed-items:3658 fstype:cifs fsname://circulans/VideoPartition mount:/media/circulans/videopart + device:2049 indexed-items:2 fstype:ext4 fsname:/dev/sda1 mount:/
Btw, dolphin also gets a little confused by this, showing the mounted share as unmounted in Places
src/engine/databasesanitizer.cpp | ||
---|---|---|
257 ↗ | (On Diff #30514) | That somehow sneaked back in. Your suggestion is good. I'll use it. |
Yes, thats exactly what I meant - device ids are not stable ...
But anyway, thats unrelated to this revision.
src/engine/experimental/databasesanitizer.cpp | ||
---|---|---|
143 ↗ | (On Diff #31996) | Better safe than sorry here. Otherwise all items of share might be removed with baloodb clean. |
src/engine/experimental/databasesanitizer.cpp | ||
---|---|---|
144 ↗ | (On Diff #31996) | Will be removed downstream |
src/engine/experimental/databasesanitizer.cpp | ||
---|---|---|
135 ↗ | (On Diff #32016) | Completely overlooked this one - should have used QStorageInfo::mountedVolumes() here instead. |