struct Gambit::Backends::backend_info

Structure providing some basic info on backend libraries.

#include <backend_info.hpp>

Public Functions

Name
backend_info()
Constructor.
~backend_info()
Destructor.
boolcustom_locations_exist() const
Indicate whether a custom backend locations file exists.
strbackend_locations() const
Return the path to any custom user backend locations file.
strdefault_backend_locations() const
Return the path to the default backend locations file.
strpath(str be, str ver) const
Return the path to a backend library.
strcorrected_path(str be, str ver) const
Return the path to a backend library with GAMBIT_DIR expanded.
strpath_dir(str be, str ver) const
Return the path to the folder in which a backend library resides.
strlib_name(str be, str ver) const
Return the bare name of the library of a backend library, with no path or extension.
strversion_from_safe_version(str be, str sv) const
Given a backend and a safe version (with no periods), return the true version.
strsafe_version_from_version(str be, str v) const
Given a backend and a true version (with periods), return the safe version.
voidlink_versions(str be, str v, str sv)
Link a backend’s version and safe version.
voidoverride_path(const str & be, const str & ver, str path)
Override a backend’s config file location.
strdefault_version(const str & be) const
Get the default version of a BOSSed backend.
std::vector< str >working_versions(const str & be)
Get all versions of a given backend that are successfully loaded.
std::vector< str >working_safe_versions(const str & be)
Get all safe versions of a given backend that are successfully loaded.
voidattempt_backend_path_override(const str & be, const str & ver, const char * name)
Try to resolve a pointer to a partial path to a shared library and use it to override the stored backend path.
intloadLibrary(const str & be, const str & ver, const str & sv, bool with_BOSS, const str & lang)
Attempt to load a backend library.

Public Attributes

Name
std::map< str, str >dlerrors
Key: backend name + version.
std::map< str, str >default_safe_versions
Key: backend name (map from BOSSed backend names to their default safe versions)
std::map< str, bool >works
Key: backend name + version.
std::map< str, bool >needsMathematica
Key: backend name + version.
std::map< str, bool >needsPython
Key: backend name + version.
std::map< str, int >missingPythonVersion
Key: backend name + version.
std::map< str, bool >classloader
Key: backend name + version.
std::map< str, bool >classes_OK
Key: backend name + version.
std::map< str, std::set< str > >classes
Key: backend name + version.
std::map< str, std::set< str > >factory_args
Key: backend name + version + class name.
std::map< str, str >constructor_status
Key: backend name + version + class name + factory args.
std::map< str, void * >loaded_C_CXX_Fortran_backends
C/C++/Fortran backends that have been successfully loaded (Key: name+version)

Public Functions Documentation

function backend_info

backend_info()

Constructor.

function ~backend_info

~backend_info()

Destructor.

function custom_locations_exist

bool custom_locations_exist() const

Indicate whether a custom backend locations file exists.

function backend_locations

str backend_locations() const

Return the path to any custom user backend locations file.

function default_backend_locations

str default_backend_locations() const

Return the path to the default backend locations file.

function path

str path(
    str be,
    str ver
) const

Return the path to a backend library.

Return the path to a backend library, given a backend name and version.

function corrected_path

str corrected_path(
    str be,
    str ver
) const

Return the path to a backend library with GAMBIT_DIR expanded.

Return the complete path to a backend library, given a backend name and version.

function path_dir

str path_dir(
    str be,
    str ver
) const

Return the path to the folder in which a backend library resides.

function lib_name

str lib_name(
    str be,
    str ver
) const

Return the bare name of the library of a backend library, with no path or extension.

function version_from_safe_version

str version_from_safe_version(
    str be,
    str sv
) const

Given a backend and a safe version (with no periods), return the true version.

function safe_version_from_version

str safe_version_from_version(
    str be,
    str v
) const

Given a backend and a true version (with periods), return the safe version.

void link_versions(
    str be,
    str v,
    str sv
)

Link a backend’s version and safe version.

function override_path

void override_path(
    const str & be,
    const str & ver,
    str path
)

Override a backend’s config file location.

function default_version

str default_version(
    const str & be
) const

Get the default version of a BOSSed backend.

function working_versions

std::vector< str > working_versions(
    const str & be
)

Get all versions of a given backend that are successfully loaded.

function working_safe_versions

std::vector< str > working_safe_versions(
    const str & be
)

Get all safe versions of a given backend that are successfully loaded.

function attempt_backend_path_override

void attempt_backend_path_override(
    const str & be,
    const str & ver,
    const char * name
)

Try to resolve a pointer to a partial path to a shared library and use it to override the stored backend path.

function loadLibrary

int loadLibrary(
    const str & be,
    const str & ver,
    const str & sv,
    bool with_BOSS,
    const str & lang
)

Attempt to load a backend library.

Public Attributes Documentation

variable dlerrors

std::map< str, str > dlerrors;

Key: backend name + version.

variable default_safe_versions

std::map< str, str > default_safe_versions;

Key: backend name (map from BOSSed backend names to their default safe versions)

variable works

std::map< str, bool > works;

Key: backend name + version.

variable needsMathematica

std::map< str, bool > needsMathematica;

Key: backend name + version.

variable needsPython

std::map< str, bool > needsPython;

Key: backend name + version.

variable missingPythonVersion

std::map< str, int > missingPythonVersion;

Key: backend name + version.

variable classloader

std::map< str, bool > classloader;

Key: backend name + version.

variable classes_OK

std::map< str, bool > classes_OK;

Key: backend name + version.

variable classes

std::map< str, std::set< str > > classes;

Key: backend name + version.

variable factory_args

std::map< str, std::set< str > > factory_args;

Key: backend name + version + class name.

variable constructor_status

std::map< str, str > constructor_status;

Key: backend name + version + class name + factory args.

variable loaded_C_CXX_Fortran_backends

std::map< str, void * > loaded_C_CXX_Fortran_backends;

C/C++/Fortran backends that have been successfully loaded (Key: name+version)


Updated on 2024-07-18 at 13:53:30 +0000