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

Add extension .phar to installed tools #439

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

Conversation

Aeliot-Tm
Copy link

PHPStorm don't understand content of PHAR file and cannot autocomplete when tool installed via link and without extension. Currently, we have to do it manually. So, this update should help to solve this issue.

image

@theseer
Copy link
Member

theseer commented Oct 27, 2024

It's actually very much intentional we drop the extension. And one of the reaons is exactly that PHPStorm does NOT "see" them. Because you exactly do NOT want to have autocomplete for code that just happens to be used by your tools.

I see that there is at least one valid edge case: PHPUnit, which happens to be a tool as well as a framework for which you'd want autocomplete when writing tests. But then again, you do NOT want auto complete for all of PHPUnit but only the relevant framework components.

Thanks for providing this PR though anyway. I have to think about this change. It feels like the wrong solution to the problem.

@Aeliot-Tm
Copy link
Author

On my point of view, it is useful not only for PHPUnit, but for all scripts which works with configs in php-files.

@Aeliot-Tm Aeliot-Tm force-pushed the add-exteension-to-installed-tools branch from 1a20241 to f8b1ab5 Compare October 29, 2024 16:08
@Aeliot-Tm Aeliot-Tm force-pushed the add-exteension-to-installed-tools branch from f8b1ab5 to 7ce133c Compare October 29, 2024 16:12
@theseer
Copy link
Member

theseer commented Nov 22, 2024

I'm still not fully convinced but am considering to add this, as you made it a configurable thing.

Did you test this on windows? Because adding .phar to a .bat file is not going to work ;)

@theseer
Copy link
Member

theseer commented Nov 22, 2024

Second question: Is the -e-Handling reflected in the data stored in the phive.xml / .phive/phars.xml respectively?

@Aeliot-Tm
Copy link
Author

This config affects only new installs case all aspects of installation of packages added before handled by .phive/phars.xml

@Aeliot-Tm
Copy link
Author

I don't quite understand why you talk about .bat files case phive should install entire phar version of scripts. Could you clarify what I am missing?

@theseer
Copy link
Member

theseer commented Nov 22, 2024

On a unix'ish OS, we use symlinks per default to map a shared phar from the location we store them into the respective project. We can, of course, easily control the target name in the project as your patch suggests.

On Windows, a .phar is not executable as windows does not have the concept of executable attributes. Thus, for windows, we deploy a .bat-file as a wrapper. (See https://github.com/phar-io/phive/blob/master/src/services/phar/WindowsPharInstaller.php and https://github.com/phar-io/phive/blob/master/conf/pharBat.template, respectively).

Your implementation seems to be unaware of this and thus would potentially only work when the phar is copied along, e.g. wenn --copy is specified.

And I'm not sure if the changed name is reflected in the phive.xml / .phive/phars.xml file when -e was used, given the location you apply the configuration option. But I haven't looked into that.

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.

2 participants