gpt4 book ai didi

python - 使用 PycParser 解析 c 文件时提取输入参数及其标识符类型

转载 作者:行者123 更新时间:2023-11-30 23:28:14 27 4
gpt4 key购买 nike

注意:熟悉 pycparser 的人会更好地理解这个问题。

我正在使用pycparser v2.10 和我试图提取 C 文件中定义的所有函数,并在解析该 C 文件时提取其输入参数名称和标识符类型(使用 pycparser)。

代码示例

import sys
sys.path.extend(['.', '..'])
CPPPATH = '../utils/cpp.exe' if sys.platform == 'win32' else 'cpp'
from pycparser import c_parser, c_ast, parse_file

class FunctionParameter(c_ast.NodeVisitor):

def visit_FuncDef(self, node):
#node.decl.type.args.params
print "Function name is", node.decl.name, "at", node.decl.coord
print " It's parameters name and type is (are)"
for params in (node.decl.type.args.params):
print " ", params.name, params.type


def func_parameter(filename):
ast = parse_file(filename, use_cpp=True, cpp_path=CPPPATH, cpp_args=r'-I../utils/fake_libc/include')

vf = FunctionParameter()
vf.visit(ast)

if __name__ == '__main__':
if len(sys.argv) > 1:
filename = sys.argv[1]
else:
filename = 'c_files/hash.c'
func_parameter(filename)

在访问FuncDef中,我打印函数名称,然后在for循环中打印参数。

问题是我能够使用 params.name 获取传递给函数的输入参数的名称。但无法使用 params.type 获取其标识符类型在 for 循环中。

有人可以告诉我如何提取参数的标识符吗?

顺便说一句,输出是这样的:

Function name is hash_func at c_files/hash.c:32
It's parameters name and type is (are)
str <pycparser.c_ast.PtrDecl object at 0x00000000024EFC88>
table_size <pycparser.c_ast.TypeDecl object at 0x00000000024EFEF0>
Function name is HashCreate at c_files/hash.c:44
It's parameters name and type is (are)
hash <pycparser.c_ast.PtrDecl object at 0x00000000024FABE0>
table_size <pycparser.c_ast.TypeDecl object at 0x00000000024FAE48>
Function name is HashInsert at c_files/hash.c:77
It's parameters name and type is (are)
hash <pycparser.c_ast.PtrDecl object at 0x00000000024F99E8>
entry <pycparser.c_ast.PtrDecl object at 0x00000000024F9BE0>
Function name is HashFind at c_files/hash.c:100
It's parameters name and type is (are)
hash <pycparser.c_ast.PtrDecl object at 0x00000000028C4160>
key <pycparser.c_ast.PtrDecl object at 0x00000000028C4358>
Function name is HashRemove at c_files/hash.c:117
It's parameters name and type is (are)
hash <pycparser.c_ast.PtrDecl object at 0x00000000028C5780>
key <pycparser.c_ast.PtrDecl object at 0x00000000028C5978>
Function name is HashPrint at c_files/hash.c:149
It's parameters name and type is (are)
hash <pycparser.c_ast.PtrDecl object at 0x00000000028E9438>
PrintFunc <pycparser.c_ast.PtrDecl object at 0x00000000028E9668>
Function name is HashDestroy at c_files/hash.c:170
It's parameters name and type is (are)
hash <pycparser.c_ast.PtrDecl object at 0x00000000028EF240>

正如您所看到的,我没有获取标识符类型,而是获取每行中的对象类型。例如<pycparser.c_ast.PtrDecl object at 0x00000000024EFC88>

我用作测试文件的示例 hash.c 文件(无论如何,它都在 pycparser 中):

/*
** C implementation of a hash table ADT
*/
typedef enum tagReturnCode {SUCCESS, FAIL} ReturnCode;


typedef struct tagEntry
{
char* key;
char* value;
} Entry;



typedef struct tagNode
{
Entry* entry;

struct tagNode* next;
} Node;


typedef struct tagHash
{
unsigned int table_size;

Node** heads;

} Hash;


static unsigned int hash_func(const char* str, unsigned int table_size)
{
unsigned int hash_value;
unsigned int a = 127;

for (hash_value = 0; *str != 0; ++str)
hash_value = (a*hash_value + *str) % table_size;

return hash_value;
}


ReturnCode HashCreate(Hash** hash, unsigned int table_size)
{
unsigned int i;

if (table_size < 1)
return FAIL;

//
// Allocate space for the Hash
//
if (((*hash) = malloc(sizeof(**hash))) == NULL)
return FAIL;

//
// Allocate space for the array of list heads
//
if (((*hash)->heads = malloc(table_size*sizeof(*((*hash)->heads)))) == NULL)
return FAIL;

//
// Initialize Hash info
//
for (i = 0; i < table_size; ++i)
{
(*hash)->heads[i] = NULL;
}

(*hash)->table_size = table_size;

return SUCCESS;
}


ReturnCode HashInsert(Hash* hash, const Entry* entry)
{
unsigned int index = hash_func(entry->key, hash->table_size);
Node* temp = hash->heads[index];

HashRemove(hash, entry->key);

if ((hash->heads[index] = malloc(sizeof(Node))) == NULL)
return FAIL;

hash->heads[index]->entry = malloc(sizeof(Entry));
hash->heads[index]->entry->key = malloc(strlen(entry->key)+1);
hash->heads[index]->entry->value = malloc(strlen(entry->value)+1);
strcpy(hash->heads[index]->entry->key, entry->key);
strcpy(hash->heads[index]->entry->value, entry->value);

hash->heads[index]->next = temp;

return SUCCESS;
}



const Entry* HashFind(const Hash* hash, const char* key)
{
unsigned int index = hash_func(key, hash->table_size);
Node* temp = hash->heads[index];

while (temp != NULL)
{
if (!strcmp(key, temp->entry->key))
return temp->entry;

temp = temp->next;
}

return NULL;
}


ReturnCode HashRemove(Hash* hash, const char* key)
{
unsigned int index = hash_func(key, hash->table_size);
Node* temp1 = hash->heads[index];
Node* temp2 = temp1;

while (temp1 != NULL)
{
if (!strcmp(key, temp1->entry->key))
{
if (temp1 == hash->heads[index])
hash->heads[index] = hash->heads[index]->next;
else
temp2->next = temp1->next;

free(temp1->entry->key);
free(temp1->entry->value);
free(temp1->entry);
free(temp1);
temp1 = NULL;

return SUCCESS;
}

temp2 = temp1;
temp1 = temp1->next;
}

return FAIL;
}


void HashPrint(Hash* hash, void (*PrintFunc)(char*, char*))
{
unsigned int i;

if (hash == NULL || hash->heads == NULL)
return;

for (i = 0; i < hash->table_size; ++i)
{
Node* temp = hash->heads[i];

while (temp != NULL)
{
PrintFunc(temp->entry->key, temp->entry->value);
temp = temp->next;
}
}
}



void HashDestroy(Hash* hash)
{
unsigned int i;

if (hash == NULL)
return;

for (i = 0; i < hash->table_size; ++i)
{
Node* temp = hash->heads[i];

while (temp != NULL)
{
Node* temp2 = temp;

free(temp->entry->key);
free(temp->entry->value);
free(temp->entry);

temp = temp->next;

free(temp2);
}
}

free(hash->heads);
hash->heads = NULL;

free(hash);
}

最佳答案

是什么让你认为你没有提取类型?

Function name is HashCreate at c_files/hash.c:44
It's parameters name and type is (are)
hash <pycparser.c_ast.PtrDecl object at 0x00000000024FABE0>
table_size <pycparser.c_ast.TypeDecl object at 0x00000000024FAE48>

名称为table_size,类型在TypeDecl中。不提供简单的类型名称 - 您必须重建它们。有关如何将“decl”解析为其文本表示形式的示例,请参阅 cdecl example .

关于python - 使用 PycParser 解析 c 文件时提取输入参数及其标识符类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21728808/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com