/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: 2013-12-08 19:28:11 UTC
  • Revision ID: tim@ed.am-20131208192811-r20qj7cgmn4duw11
initial commit; basic app startup and initial command-line processing

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.read_config( the.config_file )
34
 
 
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
 
 
47
 
                # parse config
48
 
                config = dict();
49
 
                for line in lines:
50
 
 
51
 
                        # clean up line and skip empty lines and comments
52
 
                        line = line.strip();
53
 
                        if not len( line ): continue
54
 
                        if line[ :1 ] == '#': continue
55
 
 
56
 
                        # if section
57
 
                        matches = re.match( '\[(.*)\]$', line );
58
 
                        if matches:
59
 
                                section = matches.group( 1 )
60
 
                                continue
61
 
                        matches = re.match( '([a-z0-9_-]+)\\s*=\\s*(.*)$', line, re.I )
62
 
                        if matches:
63
 
                                name = matches.group( 1 )
64
 
                                value = matches.group( 2 )
65
 
 
66
 
                                # parse value
67
 
                                matches = re.match( '(["\'])((?:\\.|[^\\1])*)\\1(?:\\s*#.*)?$',
68
 
                                                                        value )
69
 
                                if matches:
70
 
                                        value = matches.group( 2 )
71
 
                                else:
72
 
                                        matches = re.match( '([^#]+?)(?:\\s*#.*)?$', value )
73
 
                                        if( matches ):
74
 
                                                value = matches.group( 1 )
75
 
                                config[ "%s.%s" % ( section, name ) ] = value
76
 
                                print "  %s.%s = %s" % ( section, name, value )
77
 
 
78
 
                # use config
79
 
                if 'stdhome.home-dir' in config:
80
 
                        the.home_dir = config[ 'stdhome.home-dir' ]
81
 
 
82
 
                # read file matcher lists
83
 
                self.symlinks = FileMatcher( config_file, 'symlink' )
84
 
                self.ignores = FileMatcher( config_file, 'ignore' )
85
 
 
86
 
 
87
 
        def to_bool( self, value ):
88
 
                value = value.lower()
89
 
                return value == 't' || value == 'true' || value == 'yes' || \
90
 
                        ( re.match( '[0-9]+$', value ) && int( value ) != 0 )