Coverage for /media/ldata/code/tendril/tendril/gedaif/projfile.py : 0%

Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
# Copyright (C) 2015 Chintalagiri Shashank # # This file is part of Tendril. # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. """ gEDA Project File module documentation (:mod:`gedaif.projfile`) =============================================================== """
import tendril.gedaif.conffile import os
class GedaProjectFile(object):
def __init__(self, projectfolder): self.schfiles = [] self.pcbfile = None
self.configsfile = tendril.gedaif.conffile.ConfigsFile(projectfolder)
self.schfolder = os.path.join(os.path.abspath(projectfolder), 'schematic') projfilepath = os.path.join(self.schfolder, self.configsfile.configdata['projfile']) with open(projfilepath, 'r') as f: for line in f: line = self.strip_line(line) if line != '': parts = line.split('\t') if parts[0].strip() == 'schematics': for part in parts[1].split(' '): self.schfiles.append(part.strip()) if parts[0].strip('\t') == 'output-name': self.pcbfile = parts[1].strip().split('/')[-1]
@staticmethod def strip_line(line): line = line.split("#")[0] return line.strip()
@property def schpaths(self): return [os.path.join(self.schfolder, schfile) for schfile in self.schfiles]
if __name__ == "__main__": pass |