foobar.txt' */ public $title; /** * (Optional) The developer's chosen ordering key. * * This ordering takes precedence over all other orderings. For example, * if your ecosystem had a policy that all `XML=>PHP` compilations run * before all `SCSS=>CSS` compilations, then you would use different weights * for `XML=>PHP` (eg -5) and `SCSS=>CSS` (eg +5). * * NOTE: This option was added in early drafts as a pressure-relief valve * in case some control was needed over ordering. It's now hidden, though, * because I think it's better to wait for some feedback re:use-cases before * committing to this model. * * @var int */ public $weight; /** * (System-Generated) The topological order of the package which defines this * task. * * @var int */ public $packageWeight; /** * (System-Generated) Within a given package, the written ordering (from JSON) * determines natural weight. * * @var int */ public $naturalWeight; /** * (System-Generated) The name of the package which defined this task. * * @var string */ public $packageName; /** * (Required) Run commands * * List of commands to run. Each command should begin with an '@type'. * * Ex: '@php-method Foo::bar' * Ex: '@sh cp foo bar' * * @var string[] */ public $run; /** * (Required) The folder in which to execute the task. * * @var string */ public $pwd; /** * List of file-names and/or directory-names to watch. * * @see \Lurker\ResourceWatcher::track() * @var array */ public $watchFiles = []; /** * (Optional) Whether the task should be executed. * * @var bool */ public $active; /** * The file in which this task was originally defined. * * @var string */ public $sourceFile; /** * (Required) The raw task definition * * @var array */ public $definition; /** * Ensure that any required fields are defined. * @return static */ public function validate() { $missing = []; foreach (['naturalWeight', 'packageWeight', 'packageName', 'pwd', 'definition', 'run'] as $requiredField) { if ($this->{$requiredField} === null || $this->{$requiredField} === '') { $missing[] = $requiredField; } } if ($missing) { throw new \RuntimeException("Compilation task is missing field(s): " . implode(",", $missing)); } $handlers = explode('|', self::HANDLERS); foreach ($this->getParsedRun() as $run) { if (!in_array($run['type'], $handlers)) { throw new \RuntimeException("Compilation task has invalid run expression: " . json_encode($run['expr'])); } } return $this; } /** * @param string $filter * Ex: 'vendor/*' * Ex: 'vendor/package' * Ex: 'vendor/package:id' * @return bool */ public function matchesFilter($filter) { if ($this->packageName === '__root__') { return $filter === '__root__'; } list ($tgtVendorPackage, $tgtId) = explode(':', "{$filter}:"); list ($tgtVendor, $tgtPackage) = explode('/', $tgtVendorPackage . '/'); list ($actualVendor, $actualPackage) = explode('/', $this->packageName); if ($tgtVendor !== '*' && $tgtVendor !== $actualVendor) { return false; } if ($tgtPackage !== '*' && $tgtPackage !== $actualPackage) { return false; } if ($tgtId !== '' && $tgtId !== '*' && $tgtId != $this->naturalWeight) { return false; } return true; } /** * Get a list of 'run' values. * * @return array * List of the 'run' values. Each is parsed. * * Example: Suppose we have `run => ['@php foo']` * The output would be: `[['type' => 'php', 'code' => 'foo']]` */ public function getParsedRun() { $runs = []; foreach ($this->run as $runExpr) { $runs[] = $this->parseRunExpr($runExpr); } return $runs; } protected function parseRunExpr($runExpr) { if (preg_match(';^@([a-z0-9\-]+) (.*)$;', $runExpr, $m)) { return [ 'type' => $m[1], 'code' => $m[2], 'expr' => $runExpr, ]; } else { throw new \InvalidArgumentException("Failed to parse run expression: $runExpr"); } } } __halt_compiler();----SIGNATURE:----AQOPUkCEXOXbZ57h0C/umn/ymCgzR8IBdLG3RzO+Stb8Uqmb+pESTzPWKFrGAwLW1Won3j6Qw2vZ2zN0K6OHd6dxkTdPXD40adnQDpb1XfzTQcdCwqjfwqNsKG61S9fKIUGD0UUa4eFFHIRA20MM1JPHPpH7fMSPdQ1B4jWJqcKc9C5b8BhdofkJDgqMi+YijgmmrPgPywNCowv5zQjUSIWJJQr6ZCQ00sKOqY3n5JAYZv1sxGcw+RvlFmY9al9Dj1/rUx1aBe3a6EJZh4M94ZzpRDBI0a2teWqMtaWgINY/M7TElt7zndWEm4YaRb5EDs+FBoRFV4MwfTl6iOlF/hRmveYP6RQ+whIpGOmHNi6Gr44BGdtC21VcpRNVIR4LHsPQNr+2LDmvkdNeUSeMbxCBq1nBRaQR+qqnPPPAvfj2G1xo3e61fW8ndbAUNK3t09VnlkGJayRZUdxv3Lw3/iELEN7M4bj13WxQzMk5d5yckoinasbaLxjUafHykx0DsrhYPReWxtmGGodGMxHj61UDWWVMIPD/UwoYQHlaRBSiGMKE0du9QH2WtnrpPokgfrzy5vnqVCn+CClqsOBRXLSXmtzmFu0h9IWrRXI/aeqt+FB2CV4IO6FT6Ridl+qknBTi/lzYnOSyzuH6GkBeHrrzMYNA7QNMNa29Gw90WOA=----ATTACHMENT:----Njg0MDIwNjM5MjUwNzQ0NSAzMjU3NjExMzgzMTQyMjcyIDQ5NDU0ODg3Njg1NjE3Mjc=