compilertools.compilers

Compilers.

class compilertools.compilers.CompilerBase(current_compiler=False)[source]

Base class for compiler.

Arg

alias of Argument

property api

Compatibles API.

Returns:

Keys are API names, values are dict of arguments with keys in {‘link’, ‘compile’}.

Return type:

dict

clear() None.  Remove all items from D.
compile_args(arch=None, current_machine=False)[source]

Get the compiler args list for a specific architecture.

Parameters:
  • arch (str) – Target architecture name.

  • current_machine (bool) – If True, returns only arguments compatible with current machine (conditions from “Arg.import_if”).

Returns:

Arguments matrix. Keys are suffixes, values are compiler arguments.

Return type:

collections.OrderedDict with keys and values as str

compile_args_current_machine()[source]

Return compiler arguments optimized by compiler for current machine.

Returns:

Best compiler arguments for current machine.

Return type:

str

get(k[, d]) D[k] if k in D, else d.  d defaults to None.
items() a set-like object providing a view on D's items
keys() a set-like object providing a view on D's keys
property name

Compiler type name.

Returns:

Name.

Return type:

str

property option

Compatibles Options.

Returns:

Keys are options names, values are dict of arguments with keys in {‘link’, ‘compile’}.

Return type:

dict

pop(k[, d]) v, remove specified key and return the corresponding value.

If key is not found, d is returned if given, otherwise KeyError is raised.

popitem() (k, v), remove and return some (key, value) pair

as a 2-tuple; but raise KeyError if D is empty.

setdefault(k[, d]) D.get(k,d), also set D[k]=d if k not in D
update([E, ]**F) None.  Update D from mapping/iterable E and F.

If E present and has a .keys() method, does: for k in E: D[k] = E[k] If E present and lacks .keys() method, does: for (k, v) in E: D[k] = v In either case, this is followed by: for k, v in F.items(): D[k] = v

values() an object providing a view on D's values
compilertools.compilers.get_compiler(compiler=None, current_compiler=False)[source]

Return compiler class.

Parameters:
  • compiler (str of CompilerBase subclass) – Compiler Name or instance

  • current_compiler (bool) – Compiler used to build

Returns:

Compiler class instance.

Return type:

CompilerBase subclass instance