我如何静态分析php脚本,以检测全局变量的使用



我想处理一个文件夹并计算每个全局变量的次数使用。我确实有一个全局变量列表,但如果脚本检测并输出实例的名称和数量。这是无法做到的运行时。

我怀疑在PHP中使用token_get_all是可能的,但是

这是我刚刚编写的一个简单的FSM,用于演示如何从代码中提取所有全局变量:

$tokens = token_get_all('<?php function a() { global $b,
$c; } ?>');

$state = 0; // 1 for processing T_GLOBAL, 0 otherwise
$global_vars = array();
foreach ($tokens as $token) {
    if (!is_array($token)) {
        if ($state == 1 && $token == ';') {
            $state = 0;
        }
        continue;
    }
    if ($token[0] == T_GLOBAL) {
        $state = 1;
        continue;
    }
    if ($state == 1 && $token[0] == T_VARIABLE) {
        $global_vars[] = $token[1];
        continue;
    }
}
var_dump($global_vars);

为每个变量添加计数器是很容易的。

最新更新