-
Notifications
You must be signed in to change notification settings - Fork 172
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
~/.hydrogen does not follow XDG standards #643
Comments
That's because Hydrogen predates XDG spec, and |
Then how about using symlinks? |
Hi! Moving the config file to a different problem shouldn't be such a large problem, we could save the file in The data could be a larger problem since due to all of those references in song files, but a symlink for backward compatibility could work. |
Hi, |
@jeremyz I do understand that we want to transition (and encourage users to transition) from |
I like this idea, but have some questions/remarks.
To be precise, it should be moved to Therefore I fear this not as simple as it seems at first sight and on the other hand benefits are not that big. |
One solution would be to degrade gracefully for each of the two points (configuration and data) :
For configuration:
For data:
That would need a bit of work in Filesystem helper. I don't think other source files should be impacted, except the defaults in project configuration, but I gave just a brief look at the source code, and I don't really know much about Qt and Cmake :) I don't think an automatic move should be used. At most, a question could be asked to the user on startup if the configuration or the data are the old locations, if they want to migrate to new location. Or that could be a specific task available in the preferences (people keep the choice to stay with the old location or migrate) |
I've just started working on it https://github.com/hydrogen-music/hydrogen/commits/xdg |
Hi @mauser, @trebmuh, @elpescado, @riri, and others can you check xdg branch please. on a unix box, you can try it like that : |
I have never built hydrogen, and it seems I am missing some parts on ArchLinux (although dev packages are always included). I get: no rule to make the target "translations". Don't worry about that, I will check how hydrogen is packaged. Isn't there the autosave file in user's directory? (I can't find one in my current installation, but I remember seeing it) This one should be in $XDG_DATA_HOME/hydrogen |
Hi, you need qt5-tools, songs autosave files are in $XDG_DATA_HOME/hydrogen/songs |
I could build using my own build script, and it works. All data are transferred in the locations defined by XDG variables :
but data is copied.... isn't it too much if the user has a huge set of data ? Shouldn't it be moved instead? |
is the data OK, or have you paths in some xml files that still reference the old path ? moving data would be much more easier, but I fear having user reports saying 'launched H2 0.9.X I've lost all my data'. if we move data and set symlinks old_data -> new_data, running 0.9.x should work, but songs generated from it would have layer filename that wont work when going back to 1.x.y ... |
All seems ok, no reference to the old path :)
To me the message method is good, the user then knows about paths that changed. If they dont bother with geek things, they will choose whatever is the default. Those aware and sensitive to this will make their choice : move (delete old) or copy (do not delete old).
For this, once users update to 1.x.y (and then has there data migrated), they wouldn't generate new songs with 0.9.x, except hydrogen developers and testers. I don't think that's so important (but I see only my usage). Edit: I have just checked one song xml content, and in each instrument nodes, there are only the name of the drumkit and and filename (without path) for layers. |
I see now that full path is used in autosave files, should not be, will fix that ... |
The only thing that I'm afraid of is that copying user data, especially drumkits, might result in shuffling large amount of data around. That in turn might take time, freezing GUI and delaying startup in meanwhile. I'm not sure if that's real problem today, in the age of crazy fast SSDs, though. If so, maybe we should show dialog box (possibly with progress bar?) explaining what's going on? Plus, what happened when those two copies go out of sync? Alternatively, we already load drumkits from two locations: one system (/usr/local/share) and one user (~/.whatever/data). Maybe we could just add third location, XDG-compliant one, and prefer that when writing. Any thoughts? |
Any update on this? |
I made a more suitable patch, this time uses QStandardPaths to get all the XDG paths and make the files and the folders accordly.
Here's the patch for Hydrogen 1.1.1: https://gist.github.com/polirritmico/450bdc4f24d441df3b660fe852b0590b Tested and working on Gentoo. |
The code on the PR uses this logic:
|
Does this impact macOS/Windows? |
A new PR with small changes. I also create a patch for hydrogen-1.1.1 version to declutter my Linux home folder.
Yes, if no "old path" is found it should uses the paths provided by QStandarPaths:
But I don't have a Windows or macOS machine to test it. |
TBH I do not understand the point of this issue. Changing the config folder after more than 20 years feels like something that can only bring harm (and lot's of nuisance issues/bug reports) or at least I do not see the problem it solves.
I would strongly suggest to not move the config folder for macOS and Windows. Linux users may have already experience with applications moving their stuff in order to comply with freedesktop standards. But on other platforms users might only be annoyed. What's about *BSD variants? Right now we don't have a precompiler directive to distinguish them from Linux builds.
I would also suggest an error dialog in case both directories are present. I still remember the mess 10 years ago when last using a Gnome-based desktop. Config files were all over the place, some in custom folders, some in XDG compliant one, and you never knew which one took precedence. I also concur with @mauser that |
Agree, now it shouldn't affect Windows and macOS systems (PR #1624).
The point is follow the XDG standard so Linux users found configuration, data and cache files on the expected folders. Then for example if the user runs out of space on the hard drive it could easily clean A clutter home it's something that concerns many users:
I don't have any experience with *BSD, but a lot of Linux software follow the XDG standard so I don't think it would bother too much. Also, if the old
If all programs follow the standard then there shouldn't be problems like that in the first place. Anyway I could work on that; would it be enough to add an warning in the log file?
Could someone provide a <=0.9.7 song file so I can look a solution for that case? If more information or more adjustments are required, please comment so I could try to solve it. |
Hmmmm. I'm still not not that convinced. But it's not because I dislike the standard. For a new or still alpha-stable application I would agree without any discussion. It's just, Hydrogen predated the XDG standard, is around for 20 years, and there is already a small ecosystem building around it. Smaller Python/Perl/Bash scripts of users (some even publicly available on Github), personal backup or system installation scripts, test pipelines of maintainer's of different distribution etc. If any of those relies on accessing the But, on the other hand, even Emacs is young and agile enough to adopt it 😀
A popup dialog similar to the warning shown when using a development version of Hydrogen (https://github.com/hydrogen-music/hydrogen/blob/master/src/gui/src/MainForm.cpp#L2052) would be better. Typical users do not read the log.
There is one in the repo used for unit tests. https://github.com/hydrogen-music/hydrogen/blob/master/src/tests/data/song/test_song_0.9.6.h2song |
Hydrogen makes a .hydrogen directory.
XDG standards specify that config files should go in ~/.config and data in ~/.local/share.
Therefor, the
~/.hydrogen/data
directory should be moved to~/.local/share/hydrogen
andhydrogen.conf
should be moved to~/.config/hydrogen.conf
by default.The text was updated successfully, but these errors were encountered: