Skip to content

MasterAler/pylibconfig2

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

70 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pylibconfig2

Pure python library for libconfig syntax. IO works via strings, and include directives.

Usage

Scalar types are pythons basic types str, int, long, float, bool. The libconfig types Array, List, Group are implemented as ConfArray, ConfList, ConfGroup, respectively. A config is setup from a string only, and represented as a string automatically.

The config

Config represents a libconfig configuration. The string representation is itself readable as a config. Access works via attributes:

>>> import pylibconfig2 as cfg
>>> c = cfg.Config("my_setting = 5;")
>>> str(c)
'my_setting = 5;'
>>> c.my_setting
5

Or via lookup as in the original libconfig way (no exceptions are raised):

>>> c = Config('my = {nested = {sett = (0, {ng = "rocks!"})}}')
>>> c.lookup('my.nested.sett.[1].ng')
'rocks!'
>>> c.lookup('my.nested.foo', 'bar')
'bar'
Setting values should be done by path (but attribution is also possible):
>>> c = Config('')
>>> c.setup('foo', 1)
True
>>> c.setup('bar', '{hello = "world"}')
True
>>> c.lookup('bar.hello')
'world'
>>> c.setup('a.nonexisting.group', '"returns False!"')
False

These functions are given for further convenience:

keys() values() items() get(key, default) set(key, value)

An array

ConfArray represents a libconfig array. Access works via the [] operator:

>>> c = cfg.Config("my_array = [1, 2, 3];")
>>> c.my_array[1]
2

A list

ConfList represents a libconfig list. Access works via the [] operator:

>>> c = cfg.Config('my_list = (1.5, 2L, 0xee, "string");')
>>> c.my_list[1]
2L

A group

ConfGroup represents a libconfig group. Access works via attributes:

>>> c = cfg.Config("my_group = {my_setting = 5;};")
>>> c.my_group.my_setting
5

Again, these functions are given for convenience:

keys() values() items() get(key, default) set(key, value)

About

Pure python library for libconfig syntax.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%