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

Improve CodeLite symlink handling #3572

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

UffeJakobsen
Copy link
Contributor

@UffeJakobsen UffeJakobsen commented Jan 12, 2025

Subject: Improve CodeLite symlink handling

This is a new attempt at improving the symlink handling.

I know it is probably not there yet - but now I'll put it up for review :-)

I've added an attempt to have proper option handling.

Operation of FileUtils::RealPath() can be controlled in the Preferences - under the tab "Misc"

This patch improves CodeLite with projects that have symlinks in the path

If you open a file in a project that has symlinks in its path - you'll see the expanded/resolved path of the file in the window title. Also you'll typically see that CodeLite is unable find the file in the Workspace View

There are several problems in respect to symlinks and the use of realpath() calls that this patch addresses:

  • Clangd LSP returns realpath() paths

  • mainbook uses realpath() extensively to figure out if a file is already opened (in another tab).

  • CodeLite Find-In-Files uses realpath() extensively (and in the end - clicking on the found file opens it)

  • etc...

This patch basically fakes the use of FileUtils::RealPath() calls - on most occasions just returning the unmodified path.

An optional argument to FileUtils::RealPath() (defaults to false) can force the realpath() conversion (this is only used in very few occasions in this patch)

LiteEditor/editorsettingsdockingwidows.cpp Outdated Show resolved Hide resolved
Plugin/optionsconfig.cpp Outdated Show resolved Hide resolved
CodeLite/fileutils.cpp Outdated Show resolved Hide resolved
@UffeJakobsen UffeJakobsen force-pushed the master_uj_fsw_symlink_impl branch from e6729ce to ffc55ee Compare January 13, 2025 14:01
@UffeJakobsen UffeJakobsen requested a review from eranif January 13, 2025 15:55
CodeLite/fileutils.cpp Outdated Show resolved Hide resolved
CodeLite/fileutils.h Outdated Show resolved Hide resolved
CodeLite/fileutils.cpp Show resolved Hide resolved
This patch improves CodeLite with projects that have symlinks in the path

If you open a file in a project that has symlinks in its path - you'll see the expanded/resolved path of the file in the window title.
Also you'll typically see that CodeLite is unable find the file in the Workspace View

There are several problems in respect to symlinks and the use of realpath() calls that this patch addresses:

 - Clangd LSP returns realpath() paths

 - mainbook uses realpath() extensively to figure out if a file is already opened (in another tab).

 - CodeLite Find-In-Files uses realpath() extensively (and in the end - clicking on the found file opens it)

 - etc...

This patch basically fakes the use of FileUtils::RealPath() calls - on most occasions just returning the unmodified path.

An optional argument to FileUtils::RealPath() (defaults to false) can force the realpath() conversion (this is only used in very few occasions in this patch)
@UffeJakobsen UffeJakobsen force-pushed the master_uj_fsw_symlink_impl branch from ffc55ee to 761714a Compare January 15, 2025 12:18
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

Successfully merging this pull request may close these issues.

3 participants