Common python library functions for interacting with BIFROST.
Project description
bifrost-common
A library of commonly used functions to interact with BIFROST. Useful for module developers.
Installation
pip install bifrost-common-py
Components
Log
A module to print nice logging information to the console and, optionally, to files.
from bifrost_common_py.Log import Log
log = Log('myComponent', 'myApplication', options={'maxLogFileSize':1e4, 'enableLogFiles':True})
log.write(`Abandon ship`, Log.WARNING)
log.write(`Run like hell`, Log.INFO)
Log levels are DEBUG
, INFO
, WARNING
, ERROR
, FAILURE
Allowed options
are:
enableLogFiles
(default:false
): log to files as well as the consolelogDir
(default:log
): the log file directory (will be created as necessary)maxLogFileSize
(default:0
): maximum byte size of the log files, after which a new file will be started, default =0
never rollovermaxArchiveSize
(default: 5): maximum number of log files to keep
time
Some useful operations involving time, mostly for formatting Log
output.
idOfRef
Resolve the ID contained in an object. If no 'id' field is found in the
object pointed to with ref
, the last part of the reference is returned instead.
from bifrost_common_py.idOfRef import idOfRef
print(idOfRef({ 'A': { 'id': '1' }}, '/A')) // '1'
tokens
An object collecting string tokens commonly used in the BIFROST state.
import bifrost_common_py.tokens as tokens
print(tokens.tkId) // "id"
select
Selectors returning fully-qualified JSON paths into the BIFROST state.
import bifrost_common_py.pathSelectors as select
print(select.meta()) # "/meta"
print(select.dynamicId('DYNAMIC-1')) # "/dynamics/byId/DYNAMIC-1"
print(select.eventParentRef('EVENT-1')) # "/events/byId/EVENT-1/parentRef"
safepointer
A wrapper that allows to specify default values if paths can not be resolved. This is best used in conjunction with select
and a copy of the BIFROST state.
API
import bifrost_common_py.safepointer
.has(obj, path)
Determine whether the fully-qualified JSON pointer path
points to something in obj
.
safepointer.has({ 'A': { 'B': 1} }, '/A/B') # true
safepointer.has({ 'A': { 'B': 1} }, '/A/C') # false
.get(obj, path, def = null)
Resolve path
against obj
. If the path does not exist, def
is returned instead.
safepointer.get({ 'A': { 'B': 1} }, '/A/B', 0) # 1
safepointer.get({ 'A': { 'B': 1} }, '/A/C', 0) # 0
import bifrost_common_py.pathSelectors as select
safepointer.get(state, select.meta(), {}) // { id: ... }
SelectFrom
A declarative state selection library. Use this to select elements from the BIFROST state or from module subscription data.
from bifrost_common_py.SelectFrom import SelectFrom
SelectFrom(state).allDynamics().ofType('VOLTAGE-3P').asValueMap()
SelectFrom(subs).allEntries().ofType('CLIMATE-MODEL').asValueList()
SelectFrom(subs, state).allEntries().withParentOfType('WEATHER').asValueMap()
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file bifrost_common_py-0.8.tar.gz
.
File metadata
- Download URL: bifrost_common_py-0.8.tar.gz
- Upload date:
- Size: 18.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5f0993acc3eacb81680e0faf183b35da7b0acb9058753e3f796ca79a89d87ebf |
|
MD5 | e577f4fdf33c74b8050e5d8b82f5e5a5 |
|
BLAKE2b-256 | 953ea6e9221c9edc2bb007db5ff985fe8184c202a3f0747f23de56066ef0eb1d |
File details
Details for the file bifrost_common_py-0.8-py3-none-any.whl
.
File metadata
- Download URL: bifrost_common_py-0.8-py3-none-any.whl
- Upload date:
- Size: 20.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | accc2800fd6d705fde52e98b67e11b86850def3fec4a7b19e9431d00c186f64b |
|
MD5 | 0a344f4e1a7b3b431e7f26a534041f35 |
|
BLAKE2b-256 | f25db2ff8d95067d943cf11fb5b6ff5e7dfe0fa07d8e53a4c1fe91e430070a96 |