Compare commits

...

4 Commits

Author SHA1 Message Date
Pavel Shevaev fcfa71aa0c Minor renaming
Publish PHP Package / docker (push) Successful in 6s Details
2025-02-24 19:07:07 +03:00
Pavel Shevaev 22ec477ddf Improving BHL_REF validation by better splitting code by namespaces
Publish PHP Package / docker (push) Successful in 6s Details
2025-02-12 17:13:42 +03:00
Pavel Shevaev 82ad2216da Removing touching of the result file on each run; Echoing debug information only if debug=true
Publish PHP Package / docker (push) Successful in 6s Details
2024-10-22 16:14:48 +03:00
Pavel Shevaev 4a85fa9b4d Ignoring exceptions for clean, fix
Publish PHP Package / docker (push) Successful in 5s Details
2024-10-16 17:15:45 +03:00
2 changed files with 24 additions and 18 deletions

View File

@ -156,11 +156,9 @@ function bhl_run(bool $debug = true, bool $force = false, bool $exit_on_err = tr
if(!$exit_on_err) if(!$exit_on_err)
return false; return false;
} }
else else if($debug)
echo "BHL BUNDLE: total " . kb_len(filesize($result_file)) . ", CRC " . hexdec(hash_file('CRC32', $result_file, false)) . "\n"; echo "BHL BUNDLE: total " . kb_len(filesize($result_file)) . ", CRC " . hexdec(hash_file('CRC32', $result_file, false)) . "\n";
} }
@touch($result_file);
} }
function bhl_handle_error_result(array $ret_out, string $err_file, bool $exit = true) function bhl_handle_error_result(array $ret_out, string $err_file, bool $exit = true)
@ -201,7 +199,7 @@ function bhl_handle_error_result(array $ret_out, string $err_file, bool $exit =
function bhl_clean() function bhl_clean()
{ {
bhl_clean_cache(); bhl_clean_cache();
bhl_shell("clean"); bhl_shell("clean", $ret, $out);
} }
function bhl_clean_cache() function bhl_clean_cache()
@ -269,24 +267,25 @@ function bhl_validate_func_ref(string $module_file, string $func_full_name, arra
if(!$module_src) if(!$module_src)
throw new Exception("Bad module file '{$module_file}'"); throw new Exception("Bad module file '{$module_file}'");
$ns_chunks = _bhl_split_by_namespaces($module_src);
$module_chunks = array(); $module_chunks = array();
if($namespace) if($namespace)
{ {
$ns_chunks = _bhl_split_by_namespaces($module_src); if(!isset($ns_chunks[$namespace]))
if(count($ns_chunks) == 0) throw new Exception("No namespace '$namespace' found in '$module_file'");
throw new Exception("No namespaces found in '$module_file'");
foreach($ns_chunks as $ns => $ns_src) foreach($ns_chunks[$namespace] as $ns_src)
{
if($ns === $namespace)
$module_chunks[] = $ns_src; $module_chunks[] = $ns_src;
} }
if(count($module_chunks) == 0)
throw new Exception("Namespace '$namespace' for func '$func_full_name' not found in '$module_file'");
}
else else
$module_chunks[] = $module_src; {
if(!isset($ns_chunks['']))
throw new Exception("No global namespace found in '$module_file'");
foreach($ns_chunks[''] as $ns_src)
$module_chunks[] = $ns_src;
}
$signature_pattern = ''; $signature_pattern = '';
$signature_pattern .= '~func\s+'; $signature_pattern .= '~func\s+';
@ -348,12 +347,19 @@ function _bhl_split_by_namespaces(string $src) : array
{ {
$ns = trim(substr(ltrim($chunk), 9)); $ns = trim(substr(ltrim($chunk), 9));
$body = $chunks[$i+1]; $body = $chunks[$i+1];
$nss[$ns] = $body; if(!isset($nss[$ns]))
$nss[$ns] = array();
$nss[$ns][] = $body;
$i+=2; $i+=2;
} }
else else
{
if(!isset($nss['']))
$nss[''] = array();
$nss[''][] = $chunk;
++$i; ++$i;
} }
}
return $nss; return $nss;
} }

View File

@ -2,7 +2,7 @@
namespace metagen_php; namespace metagen_php;
use Exception; use Exception;
function flt_bhl_ref($val, $name, $struct, $str_args) function flt_bhl_ref($val, $name, $data, $str_args)
{ {
if(!$val) if(!$val)
return $val; return $val;