-
Notifications
You must be signed in to change notification settings - Fork 13
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
Attempting to symlink into a non-existing shared directory causes unintended conflicts #31
Comments
oof, guess I'll have to install windows to make sure things are working again as intended. Thanks for the heads up |
So today I went to develop tuckr on windows and try to spot where things are going wrong. I've fixed this error and some others causing tuckr to not function as intended on windows. Right now tuckr is usable on windows and works as intended. but I'm getting some false positive conflicts (they don't actually show up when you run |
After debugging for a little bit I found out that the reason why conflicts happen on windows is because I'm attempting to symlink a bunch of dotfiles within a so this fixed it for me:
I'll be looking into converting shared directories from symlinks to standalone directories to fix this issue. |
I've been thinking about this issue and the most performant way to do this without introducing a horrible O(n^2) type performance penalty by comparing every single path in the validation cache seems to be to outright change the data structure/approach used. I'll be conducting a big(???) change of the validation portion of the program where instead of using a struct TreeNode {
path: Dotfile,
shared: bool,
nodes: Vec<Box<TreeNode>>,
} So instead of separating everything by group all dotfiles are stored in a single source of truth "file system". if parent.any(|child| child.path.group != parent.path.group) {
parent.shared = true;
} If the node is shared, it means it should be created instead of being a symlinked directory. So far I haven't found a tree data structure that fits what I wanna do so potentially I'll be writing my own data structure for this. If I can I'll try to make it cache friendly by allocating everything contiguously. Also since this requires quite a bit of changes to make the symlinking process more accurate, I'll refrain from shipping this into the following 0.10.0 release and push it to the next release. |
At the head commit ee3c2bd I'm getting a compilation error on windows:
The text was updated successfully, but these errors were encountered: