pygccxml.utils.utils module

Logger classes and a few convenience methods.

class DeprecationWrapper(new_target, old_name, new_name, version)

Bases: object

A small wrapper class useful when deprecation classes.

This class is not part of the public API.

class cached(method)

Bases: property

Convert a method into a cached attribute.

reset()
contains_parent_dir(fpath, dirs)

Returns true if paths in dirs start with fpath.

Precondition: dirs and fpath should be normalized before calling this function.

create_temp_file_name(suffix, prefix=None, directory=None)

Small convenience function that creates temporary files.

This function is a wrapper around the Python built-in function tempfile.mkstemp.

class cxx_standard(cflags)

Bases: object

Helper class for parsing the C++ standard version.

This class holds the C++ standard version the XML generator has been configured with, and provides helpers functions for querying C++ standard version related information.

property is_cxx03

Returns true if -std=c++03 is being used

property is_cxx11

Returns true if -std=c++11 is being used

property is_cxx11_or_greater

Returns true if -std=c++11 or a newer standard is being used

property is_cxx14

Returns true if -std=c++14 is being used

property is_cxx14_or_greater

Returns true if -std=c++14 or a newer standard is being used

property is_cxx1z

Returns true if -std=c++1z is being used

property is_implicit

Indicates whether a -std=c++xx was specified

property stdcxx

Returns the -std=c++xx option passed to the constructor

find_xml_generator(name='castxml')

Try to find a c++ parser (xml generator)

Parameters

name (str) – name of the c++ parser (e.g. castxml)

Returns

path to the xml generator and it’s name

Return type

path (str), name (str)

If no c++ parser is found the function raises an exception. pygccxml does currently only support castxml as c++ parser.

get_architecture()

Returns computer architecture: 32 or 64.

The guess is based on maxint.

get_tr1(name)

In libstd++ the tr1 namespace needs special care.

Return either an empty string or tr1::, useful for appending to search patterns.

Parameters

name (str) – the name of the declaration

Returns

an empty string or “tr1::”

Return type

str

is_str(string)

Python 2 and 3 compatible string checker.

Parameters

string (str | basestring) – the string to check

Returns

True or False

Return type

bool

class loggers

Bases: object

Class-namespace, defines a few loggers classes, used in the project.

all_loggers = [<Logger pygccxml (WARNING)>, <Logger pygccxml.cxx_parser (INFO)>, <Logger pygccxml.queries_engine (INFO)>, <Logger pygccxml.declarations_cache (INFO)>, <Logger pygccxml.pdb_reader (INFO)>]

Contains all logger classes, defined by the class.

cxx_parser = <Logger pygccxml.cxx_parser (INFO)>

Logger for C++ parser functionality

If you set this logger level to DEBUG, you will be able to see the exact command line, used to invoke GCC-XML and errors that occures during XML parsing

declarations_cache = <Logger pygccxml.declarations_cache (INFO)>

Logger for declarations tree cache functionality

If you set this logger level to DEBUG, you will be able to see what is exactly happens, when you read the declarations from cache file. You will be able to decide, whether it worse for you to use this or that cache strategy.

pdb_reader = <Logger pygccxml.pdb_reader (INFO)>

Logger for MS .pdb file reader functionality

queries_engine = <Logger pygccxml.queries_engine (INFO)>

Logger for query engine functionality.

If you set this logger level to DEBUG, you will be able to see what queries you do against declarations tree, measure performance and may be even to improve it. Query engine reports queries and whether they are optimized or not.

root = <Logger pygccxml (WARNING)>

Root logger exists for your convenience only.

static set_level(level)

Set the same logging level for all the loggers at once.

normalize_path(some_path)

Return os.path.normpath(os.path.normcase(some_path)).

remove_file_no_raise(file_name, config)

Removes file from disk if exception is raised.