/stdhome

To get this branch, use:
bzr branch http://bzr.ed.am/stdhome

« back to all changes in this revision

Viewing changes to lib/stdhome/config.py

  • Committer: Tim Marston
  • Date: 2016-04-10 21:03:07 UTC
  • Revision ID: tim@ed.am-20160410210307-6m8527mg1syvrual
updated todo

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# config.py
 
2
#
 
3
# Copyright (C) 2014 Tim Marston <tim@edm.am>
 
4
#
 
5
# This file is part of stdhome (hereafter referred to as "this program").
 
6
# See http://ed.am/dev/stdhome for more information.
 
7
#
 
8
# This program is free software: you can redistribute it and/or modify
 
9
# it under the terms of the GNU General Public License as published by
 
10
# the Free Software Foundation, either version 3 of the License, or
 
11
# (at your option) any later version.
 
12
#
 
13
# This program is distributed in the hope that it will be useful,
 
14
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
15
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
16
# GNU General Public License for more details.
 
17
#
 
18
# You should have received a copy of the GNU General Public License
 
19
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
20
 
 
21
 
 
22
import os, re, errno
 
23
from file_matcher import FileMatcher
 
24
import the
 
25
 
 
26
 
 
27
class Config:
 
28
 
 
29
 
 
30
        def __init__( self ):
 
31
                self.symlinks = None
 
32
                self.ignores = None
 
33
                self.default_vcs = 'bzr'
 
34
                self.read_config( the.config_file )
 
35
 
 
36
        def read_config( self, config_file ):
 
37
 
 
38
                # read file
 
39
                if the.verbose >= 1: print "reading config: %s" % ( config_file )
 
40
                file = os.path.expanduser( config_file )
 
41
                try:
 
42
                        with open( file ) as f:
 
43
                                lines = f.readlines()
 
44
                except IOError as e:
 
45
                        if e.errno != errno.ENOENT: raise
 
46
                        lines = list()
 
47
 
 
48
                # parse config
 
49
                config = dict();
 
50
                for line in lines:
 
51
 
 
52
                        # clean up line and skip empty lines and comments
 
53
                        line = line.strip();
 
54
                        if not len( line ): continue
 
55
                        if line[ :1 ] == '#': continue
 
56
 
 
57
                        # if section
 
58
                        matches = re.search( '^\[(.*)\]$', line );
 
59
                        if matches:
 
60
                                section = matches.group( 1 )
 
61
                                continue
 
62
                        matches = re.search( '^([a-z0-9_-]+)\\s*=\\s*(.*)$', line, re.I )
 
63
                        if matches:
 
64
                                name = matches.group( 1 )
 
65
                                value = matches.group( 2 )
 
66
 
 
67
                                # parse value
 
68
                                matches = re.search(
 
69
                                        '^(["\'])((?:\\.|[^\\1])*)\\1(?:\\s*#.*)?$', value )
 
70
                                if matches:
 
71
                                        value = matches.group( 2 )
 
72
                                else:
 
73
                                        matches = re.search( '^([^#]+?)(?:\\s*#.*)?$', value )
 
74
                                        if( matches ):
 
75
                                                value = matches.group( 1 )
 
76
                                config[ "%s.%s" % ( section, name ) ] = value
 
77
                                #print "  %s.%s = %s" % ( section, name, value )
 
78
 
 
79
                # use config
 
80
                if 'stdhome.home-dir' in config:
 
81
                        the.home_dir = config[ 'stdhome.home-dir' ]
 
82
                if 'stdhome.default-vcs' in config:
 
83
                        self.default_vcs = config[ 'stdhome.default-vcs' ]
 
84
 
 
85
                # read file matcher lists
 
86
                self.symlinks = FileMatcher( config_file, 'symlink' )
 
87
                self.ignores = FileMatcher( config_file, 'ignore' )
 
88
 
 
89
 
 
90
        def to_bool( self, value ):
 
91
                value = value.lower()
 
92
                return value == 't' or value == 'true' or value == 'yes' or \
 
93
                        ( re.search( '^[0-9]+$', value ) and int( value ) != 0 )