Name
Asm::C - Extract macro values and structure details from C programs.
Synopsis
Extract structure details from C programs.
Given:
struct S
{int a;
int b;
int c;
} s;
void main() {}
Get:
is_deeply extractCStructure($input),
{ S => bless({
fields => {
a => bless({field => "a", loc => 0, size => 4, type => "int"}, "field"),
b => bless({field => "b", loc => 4, size => 4, type => "int"}, "field"),
c => bless({field => "c", loc => 8, size => 4, type => "int"}, "field"),
},
size => 12,
}, "structure")};
Extract macro values from a C header file.
Find the value of a macro definition in a C header file:
my $m = extractMacroDefinitionsFromCHeaderFile("linux/mman.h");
is_deeply $$m{MAP_ANONYMOUS}, "0x20";
Description
Extract macro values and structure details from C programs.
Version "20210328".
The following sections describe the methods in each functional area of this module. For an alphabetic listing of all methods by name see Index.
Asm::C
Extract macro values and structure details from C programs.
Structures
Extract structure details from C programs.
extractCStructure($input)
Extract the details of a structure
Parameter Description
1 $input Input C file - a temporary one is ok
Example:
is_deeply extractCStructure($input), # 𝗘𝘅𝗮𝗺𝗽𝗹𝗲
extractCField($input, $structure, $field)
Extract the details of a field in a structure in a C file
Parameter Description
1 $input Input file
2 $structure Structure name
3 $field Field within structure
Example:
if (1)
{my $input = writeTempFile <<END;
struct S
{int a;
int b;
int c;
} s;
extractCFieldLoc($input, $structure, $field)
Extract the offset to the location of a field in a structure in a C file
Parameter Description
1 $input Input file
2 $structure Structure name
3 $field Field within structure
Example:
if (1)
{my $input = writeTempFile <<END;
struct S
{int a;
int b;
int c;
} s;
extractCFieldSize($input, $structure, $field)
Extract the size of a field in a structure in a C file
Parameter Description
1 $input Input file
2 $structure Structure name
3 $field Field within structure
Example:
if (1)
{my $input = writeTempFile <<END;
struct S
{int a;
int b;
int c;
} s;
extractCFieldType($input, $structure, $field)
Extract the type of a field in a structure in a C file
Parameter Description
1 $input Input file
2 $structure Structure name
3 $field Field within structure
Example:
if (1)
{my $input = writeTempFile <<END;
struct S
{int a;
int b;
int c;
} s;
extractCStructureFields($input, $structure)
Extract the names of the fields in a C structure
Parameter Description
1 $input Input file
2 $structure Structure name
Example:
if (1)
{my $input = writeTempFile <<END;
struct S
{int a;
int b;
int c;
} s;
extractCStructureSize($input, $structure)
Extract the size of a C structure
Parameter Description
1 $input Input file
2 $structure Structure name
Example:
if (1)
{my $input = writeTempFile <<END;
struct S
{int a;
int b;
int c;
} s;
Macros
Extract macro values from C header files
extractMacroDefinitionsFromCHeaderFile($includeFile)
Extract the macro definitions found in a C header file using gcc
Parameter Description
1 $includeFile C Header file name as it would be entered in a C program
Example:
if (1)
{my $h = "linux/mman.h";
my $m = extractMacroDefinitionsFromCHeaderFile("linux/mman.h"); # 𝗘𝘅𝗮𝗺𝗽𝗹𝗲
is_deeply $$m{MAP_ANONYMOUS}, "0x20";
ok extractMacroDefinitionFromCHeaderFile("linux/mman.h", q(PROT_WRITE)) eq "0x2";
}
extractMacroDefinitionFromCHeaderFile($includeFile, $macro)
Extract a macro definitions found in a C header file using gcc
Parameter Description
1 $includeFile C Header file name as it would be entered in a C program
2 $macro Macro name
Example:
if (1)
{my $h = "linux/mman.h";
my $m = extractMacroDefinitionsFromCHeaderFile("linux/mman.h");
is_deeply $$m{MAP_ANONYMOUS}, "0x20";
ok extractMacroDefinitionFromCHeaderFile("linux/mman.h", q(PROT_WRITE)) eq "0x2"; # 𝗘𝘅𝗮𝗺𝗽𝗹𝗲
}
Index
1 extractCField - Extract the details of a field in a structure in a C file
2 extractCFieldLoc - Extract the offset to the location of a field in a structure in a C file
3 extractCFieldSize - Extract the size of a field in a structure in a C file
4 extractCFieldType - Extract the type of a field in a structure in a C file
5 extractCStructure - Extract the details of a structure
6 extractCStructureFields - Extract the names of the fields in a C structure
7 extractCStructureSize - Extract the size of a C structure
8 extractMacroDefinitionFromCHeaderFile - Extract a macro definitions found in a C header file using gcc
9 extractMacroDefinitionsFromCHeaderFile - Extract the macro definitions found in a C header file using gcc
Installation
This module is written in 100% Pure Perl and, thus, it is easy to read, comprehend, use, modify and install via cpan:
sudo cpan install Asm::C
Author
Copyright
Copyright (c) 2016-2021 Philip R Brenan.
This module is free software. It may be used, redistributed and/or modified under the same terms as Perl itself.