Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Avoid File overwritten when autoSave=true #369

Open
Bluey26 opened this issue Jun 1, 2024 · 2 comments
Open

Avoid File overwritten when autoSave=true #369

Bluey26 opened this issue Jun 1, 2024 · 2 comments

Comments

@Bluey26
Copy link

Bluey26 commented Jun 1, 2024

Expected Behavior

Screengrab should (in my opinion) have a way to 'detect' that the 'following' filename is already present, and write to the next one, even if the file was not created by screengrab

Current Behavior

When autoSave=true (Avoids the need to open a filedialog and save the file), the program writes the image to the file corresponding to the 'next one', but according to screengrab. What i think its happening is that screengrab 'stores' the last name or the last filename generated by screengrab(all the screengrab filenames?) and then uses the N+1 (where N is the last number) as filename. This causes problems at the moment (at least for me), because since ScreenGrab is not fully working in wayland session (i use a grim script), when i go back to X11 to screen or capture an image (screengrab working) the file overwrites a file already present and made by the grim script.

My grim script basically goes to the folder where all the screens are saved(is the same for ScreenGrab) and stores is following the same arguments for name and extension:

grim -t jpeg -q 100 -g "$(slurp)" screen$(ls screen* | wc -l).jpg && notify-send -a grim -i screengrab -t 2000 "Se ha guardado la captura"

This is just to have all the pictures sorted and organized, but it has the problem i describe ( i used to have 2 separated folders for each program, but that made me forgot where the screen i was looking for was located).

As you can see in the script line (its inside a .sh which is launched using labwc rc.xml, the script checks beforehand the numbers of the pictures (screen screen01 screen02 ,etc) and then uses the number of pictures as number for the file:
if there are 2000 pictures (1999 is the last number , plus screen.jpg which does not have a number), the resulting screenshot would have the name screen2000.jpg

I know this is just a script and that it just works, and that ScreenGrab will work in the future for Wayland sessions too, but this would make me delete a lot of pictures or rename/move them to avoid overwriting.

Possible Solution

Detecting the filenames in the folder in another way, or having an option to do so, plus the current behavior

Steps to Reproduce (for bugs)
  1. taking a screenshoot using the grim script
  2. Login on x11 and taking a screenshoot with the same name-syntax and same directory
  3. the screenshoot taken with screengrab will overwrite the screenshot taken with the other program, if autoSave=true in the screengrab configuration.
Context

I enter from time to time to X11 and sometimes i need to take screenshots. I discovered that the screenshots where not at the end of the folder ( i have sorting by time of modification)

System Information
  • Distribution & Version: Archlinux
  • Kernel: 6.9.2-arch1-1
  • Qt Version: 6.7.1
  • libqtxdg Version: 4.0.0-2
  • lxqt-build-tools Version: 2.0.0-1
  • Package version: 2.8.0-1
@tsujan
Copy link
Member

tsujan commented Jun 1, 2024

In general, I agree that if an app "auto-saves" something, it shouldn't overwrite a file which hasn't been opened by it. Since Screengrab doesn't open files, it shouldn't overwrite any either.

Sorry, I didn't have time to read all of your comment. So, tell me if you meant something else — but please, concisely.

@Bluey26
Copy link
Author

Bluey26 commented Jun 1, 2024

Yes, in a short way, screengrab overwrites the files generated by another screenshot tool, grim, if i use the same name syntax and directory, which i find undesirable.

This happens with autosave=true should not when false because it will open filedialog

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants