我相信通过一些黑客攻击,我可以找到一种方法来做到这一点,但我希望有一个优雅的解决方案。我需要能够检测我的软件包何时从工作台运行,或者软件包是否已安装并作为第三方运行。
您可以在主包类中创建一个方法来执行检查,如下所示:
MyClass {
protected function getPackageLocation()
{
// Check if the path to this file contains 'workbench'
if (strpos(realpath(__FILE__), 'workbench') !== false) {
return 'workbench';
}
// If not, it's in vendor folder
return 'vendor';
}
}
如果需要从包外部检查它,则始终可以将函数公开。
为了使其更可靠,您可以在条件中检查workbench/your_vendor/your_package/
,甚至可以使用以下内容使其动态化:
// untested: translate namespace to path format
$needle = 'workspace/' . strtolower(str_replace("_", "/", __NAMESPACE__));
if (strpos(realpath(__FILE__), $needle) !== false) {
...