1 |
#!/usr/bin/python |
---|
2 |
# |
---|
3 |
# Copyright (C) 2008 by Arnold Krille |
---|
4 |
# |
---|
5 |
# This file is part of FFADO |
---|
6 |
# FFADO = Free Firewire (pro-)audio drivers for linux |
---|
7 |
# |
---|
8 |
# FFADO is based upon FreeBoB. |
---|
9 |
# |
---|
10 |
# This program is free software: you can redistribute it and/or modify |
---|
11 |
# it under the terms of the GNU General Public License as published by |
---|
12 |
# the Free Software Foundation, either version 3 of the License, or |
---|
13 |
# (at your option) any later version. |
---|
14 |
# |
---|
15 |
# This program is distributed in the hope that it will be useful, |
---|
16 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
17 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
18 |
# GNU General Public License for more details. |
---|
19 |
# |
---|
20 |
# You should have received a copy of the GNU General Public License |
---|
21 |
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
---|
22 |
# |
---|
23 |
|
---|
24 |
import re, os |
---|
25 |
|
---|
26 |
import shlex |
---|
27 |
|
---|
28 |
import logging |
---|
29 |
log = logging.getLogger('configparser') |
---|
30 |
|
---|
31 |
class DeviceList: |
---|
32 |
def __init__( self, filename="" ): |
---|
33 |
self.devices = list() |
---|
34 |
if not filename == "": |
---|
35 |
self.updateFromFile( filename ) |
---|
36 |
|
---|
37 |
def updateFromFile( self, filename ): |
---|
38 |
filename = os.path.expanduser(filename) |
---|
39 |
log.debug("DeviceList::updateFromFile(%s)" % filename) |
---|
40 |
if not os.path.exists( filename ): |
---|
41 |
log.error("cannot open file") |
---|
42 |
f = open( filename, "r" ) |
---|
43 |
|
---|
44 |
lex = Parser( f ) |
---|
45 |
config = {} |
---|
46 |
while lex.peaktoken() != lex.eof: |
---|
47 |
tmp = lex.parsenamedvalue() |
---|
48 |
if tmp != None: |
---|
49 |
config[ tmp[0] ] = tmp[1] |
---|
50 |
for dev in config["device_definitions"]: |
---|
51 |
self.addDevice( dev ) |
---|
52 |
|
---|
53 |
def getDeviceById( self, vendor, model ): |
---|
54 |
log.debug("DeviceList::getDeviceById( %s, %s )" % (vendor, model )) |
---|
55 |
for dev in self.devices: |
---|
56 |
if int("%s" % dev['vendorid'], 0) == int("%s" % vendor, 0) and \ |
---|
57 |
int("%s" % dev['modelid'], 0) == int("%s" % model, 0): |
---|
58 |
return dev |
---|
59 |
tmp = dict() |
---|
60 |
self.devices.append( tmp ) |
---|
61 |
return tmp |
---|
62 |
|
---|
63 |
def addDevice( self, device_dict ): |
---|
64 |
log.debug("DeviceList::addDevice()") |
---|
65 |
dev = self.getDeviceById( device_dict['vendorid'], device_dict['modelid'] ) |
---|
66 |
dev.update( device_dict ) |
---|
67 |
|
---|
68 |
class Parser: |
---|
69 |
def __init__( self, file ): |
---|
70 |
self.lex = shlex.shlex( file ) |
---|
71 |
self.eof = self.lex.eof |
---|
72 |
|
---|
73 |
def peaktoken( self ): |
---|
74 |
token = self.lex.get_token() |
---|
75 |
self.lex.push_token( token ) |
---|
76 |
return token |
---|
77 |
|
---|
78 |
def parselist( self, level="" ): |
---|
79 |
token = self.peaktoken() |
---|
80 |
if token != "(": |
---|
81 |
return |
---|
82 |
self.lex.get_token() |
---|
83 |
log.debug("%sWill parse list" % level) |
---|
84 |
ret = [] |
---|
85 |
token = self.peaktoken() |
---|
86 |
while token != ")": |
---|
87 |
ret.append( self.parsenamedvalue( level+" " ) ) |
---|
88 |
token = self.peaktoken() |
---|
89 |
log.debug("%slist is %s" % (level, str(ret))) |
---|
90 |
self.lex.get_token() |
---|
91 |
if self.peaktoken() == ",": |
---|
92 |
log.debug("%sFound a delimiter" % level) |
---|
93 |
self.lex.get_token() |
---|
94 |
return ret |
---|
95 |
|
---|
96 |
def parsemap( self, level="" ): |
---|
97 |
token = self.lex.get_token() |
---|
98 |
if token != "{": |
---|
99 |
return |
---|
100 |
log.debug("%sWill parse map" % level) |
---|
101 |
ret = {} |
---|
102 |
token = self.peaktoken() |
---|
103 |
while token != "}": |
---|
104 |
#self.push_token( token ) |
---|
105 |
tmp = self.parsenamedvalue( level+" " ) |
---|
106 |
if tmp != None: |
---|
107 |
ret[ tmp[0] ] = tmp[1] |
---|
108 |
token = self.peaktoken() |
---|
109 |
token = self.lex.get_token() |
---|
110 |
log.debug("%sMap ended with '%s' and '%s'"% (level,token,self.peaktoken())) |
---|
111 |
if self.peaktoken() in (",",";"): |
---|
112 |
log.debug("%sFound a delimiter!" % level) |
---|
113 |
self.lex.get_token() |
---|
114 |
return ret |
---|
115 |
|
---|
116 |
def parsevalue( self, level="" ): |
---|
117 |
token = self.lex.get_token() |
---|
118 |
log.debug("%sparsevalue() called on token '%s'" % (level, token)) |
---|
119 |
self.lex.push_token( token ) |
---|
120 |
if token == "(": |
---|
121 |
value = self.parselist( level+" " ) |
---|
122 |
elif token == "{": |
---|
123 |
value = self.parsemap( level+" " ) |
---|
124 |
else: |
---|
125 |
value = self.lex.get_token().replace( "\"", "" ) |
---|
126 |
token = self.peaktoken() |
---|
127 |
if token == ";": |
---|
128 |
log.debug("%sFound a delimiter!" % level) |
---|
129 |
self.lex.get_token() |
---|
130 |
return value |
---|
131 |
|
---|
132 |
def parsenamedvalue( self, level="" ): |
---|
133 |
token = self.lex.get_token() |
---|
134 |
log.debug("%sparsenamedvalue() called on token '%s'" % (level, token)) |
---|
135 |
if token == "{": |
---|
136 |
self.lex.push_token( token ) |
---|
137 |
return self.parsemap( level+" " ) |
---|
138 |
if len(token) > 0 and token not in ("{","}","(",")",",",";"): |
---|
139 |
log.debug("%sGot name '%s'" %(level,token)) |
---|
140 |
name = token |
---|
141 |
token = self.lex.get_token() |
---|
142 |
if token in ("=",":"): |
---|
143 |
#print "%sWill parse value" % level |
---|
144 |
value = self.parsevalue( level ) |
---|
145 |
return (name,value) |
---|
146 |
log.debug("%sparsenamedvalue() will return None!" % level) |
---|
147 |
return |
---|
148 |
|
---|
149 |
# |
---|
150 |
# Have kind of a test directly included... |
---|
151 |
# |
---|
152 |
if __name__ == "__main__": |
---|
153 |
|
---|
154 |
import sys |
---|
155 |
|
---|
156 |
file = sys.argv[1] |
---|
157 |
|
---|
158 |
log.setLevel(logging.DEBUG) |
---|
159 |
devs = DeviceList( file ) |
---|
160 |
|
---|
161 |
print devs.devices |
---|
162 |
|
---|