Compare commits

..

No commits in common. "master" and "v0.0.5" have entirely different histories.

3 changed files with 14 additions and 57 deletions

View File

@ -1,5 +0,0 @@
## v0.0.7
- Setting proper PATH when checking for dotnet during composer post-install step
## v0.0.6
- Initial working version

View File

@ -1,13 +1,12 @@
<?php
namespace taskman;
use Exception;
task('dotnet_set_env', ['always' => true], function() {
dotnet_set_env();
});
task('dotnet_install', function(array $args) {
DotnetSupport::installEx(isset($args[0]) && $args[0] === '--force');
task('dotnet_install', function() {
DotnetSupport::install();
});
function dotnet_shell($cmd)
@ -22,8 +21,11 @@ function dotnet_shell_get($cmd)
function dotnet_set_env()
{
//TODO: do we need this one?
putenv("DOTNET_CLI_TELEMETRY_OPTOUT=1");
DotnetSupport::addEnvPath();
$dotnet_path = DotnetSupport::getPath();
if(is_win())
putenv("PATH=$dotnet_path;".getenv('PATH'));
else
putenv("PATH=$dotnet_path:".getenv('PATH'));
}

View File

@ -1,25 +1,18 @@
<?php
namespace taskman;
use Exception;
//NOTE: this class must not have any dependencies on any packages
class DotnetSupport
{
const VERSION = "8.0.0";
//NOTE: this is a composer event, it doesn't accept any arguments
static function install()
{
self::installEx(false);
}
static function installEx(bool $force = false)
{
$version = self::VERSION;
$has_dotnet = true;
$dotnet_curr_ver = "";
//let's add to PATH
$prev_path = self::addEnvPath();
try
{
$dotnet_curr_ver = self::shellGet("dotnet --version");
@ -27,35 +20,22 @@ class DotnetSupport
}
catch(\Throwable $th)
{
$force = true;
}
finally
{
//let's restore prev PATH
self::setEnvPath($prev_path);
$has_dotnet = false;
}
if(!$force)
{
$dotnet_ver_items = explode('.', $dotnet_curr_ver);
$target_ver_items = explode('.', $version);
//let's force install if current major version is not equal
$force = isset($dotnet_ver_items[0]) && $dotnet_ver_items[0] !== $target_ver_items[0];
}
if(!$force)
if($has_dotnet && version_compare($dotnet_curr_ver, $version) >= 0)
return;
print("DOTNET VERSION MISMATCH: $dotnet_curr_ver is not compatible with $version\n");
print("DOTNET VERSION MISMATCH: $dotnet_curr_ver < $version\n");
$install_file_path = self::getInstallerPath();
$version_parts = explode('.', $version);
$channel = $version_parts[0].'.'.$version_parts[1];
if(self::isWin())
self::shell("powershell -NoProfile -ExecutionPolicy unrestricted Invoke-Expression '\"$install_file_path\" -Channel $channel'");
self::Shell("powershell -NoProfile -ExecutionPolicy unrestricted Invoke-Expression '\"$install_file_path\" -Channel $channel'");
else
self::shell("\"$install_file_path\" --channel $channel");
self::Shell("\"$install_file_path\" --channel $channel");
}
static function getInstallerPath() : string
@ -79,26 +59,6 @@ class DotnetSupport
}
}
static function addEnvPath(string $path = '') : string
{
$prev_path = getenv('PATH');
if(!$path)
$path = DotnetSupport::getPath();
if(self::isWin())
self::setEnvPath("$path;$prev_path");
else
self::setEnvPath("$path:$prev_path");
return $prev_path;
}
static function setEnvPath(string $path)
{
putenv("PATH=$path");
}
static function isWin() : bool
{
return !(DIRECTORY_SEPARATOR == '/');