summaryrefslogtreecommitdiff
path: root/services/Thumbnailer.qml
diff options
context:
space:
mode:
author2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-05-05 22:15:31 +1000
committer2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-05-05 22:15:31 +1000
commitdff2bde9a3a5dba78deb799919224e8f33f11ce2 (patch)
treef42bd8422865bf640ba01a9dab44ae2bd53d612e /services/Thumbnailer.qml
parentfeat: show osd on border hover (diff)
downloadcaelestia-shell-dff2bde9a3a5dba78deb799919224e8f33f11ce2.tar.gz
caelestia-shell-dff2bde9a3a5dba78deb799919224e8f33f11ce2.tar.bz2
caelestia-shell-dff2bde9a3a5dba78deb799919224e8f33f11ce2.zip
thumbnailer: use single process + load original
Diffstat (limited to 'services/Thumbnailer.qml')
-rw-r--r--services/Thumbnailer.qml54
1 files changed, 25 insertions, 29 deletions
diff --git a/services/Thumbnailer.qml b/services/Thumbnailer.qml
index 3b22ada..3d7a6c1 100644
--- a/services/Thumbnailer.qml
+++ b/services/Thumbnailer.qml
@@ -11,11 +11,12 @@ Singleton {
readonly property string thumbDir: `${StandardPaths.standardLocations(StandardPaths.GenericCacheLocation)[0]}/caelestia/thumbnails`.slice(7)
- function go(path: string, width: int, height: int): var {
- return thumbComp.createObject(root, {
- originalPath: path,
- width: width,
- height: height
+ function go(obj: var): var {
+ return thumbComp.createObject(obj, {
+ originalPath: obj.path,
+ width: obj.width,
+ height: obj.height,
+ loadOriginal: obj.loadOriginal
});
}
@@ -25,46 +26,41 @@ Singleton {
required property string originalPath
required property int width
required property int height
+ required property bool loadOriginal
property string path
- readonly property Process shaProc: Process {
+ readonly property Process proc: Process {
running: true
- command: ["sha1sum", obj.originalPath]
- stdout: SplitParser {
- onRead: data => {
- const sha = data.split(" ")[0];
- obj.path = `${root.thumbDir}/${sha}@${obj.width}x${obj.height}-exact.png`;
- obj.thumbProc.signal(9);
- obj.thumbProc.running = true;
- }
- }
- }
-
- readonly property Process thumbProc: Process {
command: ["fish", "-c", `
-if test -f ${obj.path}
- exit 1
+set -l path "${root.thumbDir}/$(sha1sum ${obj.originalPath} | cut -d ' ' -f 1)@${obj.width}x${obj.height}-exact.png"
+if test -f $path
+ echo $path
else
+ echo 'start'
set -l size (identify -ping -format '%w\n%h' ${obj.originalPath})
if test $size[1] -gt ${obj.width} -o $size[2] -gt ${obj.height}
- magick ${obj.originalPath} -${obj.width > 1024 || obj.height > 1024 ? "resize" : "thumbnail"} ${obj.width}x${obj.height}^ -background none -gravity center -extent ${obj.width}x${obj.height} -unsharp 0x.5 ${obj.path}
+ magick ${obj.originalPath} -${obj.width > 1024 || obj.height > 1024 ? "resize" : "thumbnail"} ${obj.width}x${obj.height}^ -background none -gravity center -extent ${obj.width}x${obj.height} -unsharp 0x.5 $path
else
- cp ${obj.originalPath} ${obj.path}
+ cp ${obj.originalPath} $path
end
+ echo $path
end`]
- onExited: code => {
- if (code === 0) {
- const path = obj.path;
- obj.path = "";
- obj.path = path;
+ stdout: SplitParser {
+ onRead: data => {
+ if (data === "start") {
+ if (obj.loadOriginal)
+ obj.path = obj.originalPath;
+ } else {
+ obj.path = data;
+ }
}
}
}
function reload(): void {
- shaProc.signal(9);
- shaProc.running = true;
+ proc.signal(9);
+ proc.running = true;
}
}