mirror of
https://github.com/phodina/ProjectConverter.git
synced 2026-04-30 19:09:16 +08:00
Pylint refactoring on ewpproject.py
This commit is contained in:
parent
e3fad2d08b
commit
fca8ab0bd7
@ -1,12 +1,18 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
""" Module for converting EWP project format file
|
||||
@file
|
||||
"""
|
||||
|
||||
import os
|
||||
from lxml import objectify
|
||||
|
||||
class EWPProject (object):
|
||||
|
||||
class EWPProject(object):
|
||||
""" Class for converting EWP project format file
|
||||
"""
|
||||
|
||||
def __init__(self, path, xmlFile):
|
||||
|
||||
self.project = {}
|
||||
self.path = path
|
||||
self.xmlFile = xmlFile
|
||||
@ -14,9 +20,9 @@ class EWPProject (object):
|
||||
self.root = xmltree.getroot()
|
||||
|
||||
def parseProject(self):
|
||||
|
||||
""" Parses EWP project file for project settings
|
||||
"""
|
||||
self.project['name'] = self.root.configuration.name
|
||||
|
||||
self.project['chip'] = ''
|
||||
|
||||
#TODO: parse into tree structure
|
||||
@ -27,10 +33,8 @@ class EWPProject (object):
|
||||
self.project['incs'] = []
|
||||
|
||||
for element in self.root.configuration.getchildren():
|
||||
|
||||
if element.tag == 'settings':
|
||||
for e in element.data.getchildren():
|
||||
|
||||
if e.tag == 'option':
|
||||
if e.name.text == 'OGChipSelectEditMenu':
|
||||
self.project['chip'] = str(e.state)
|
||||
@ -44,19 +48,17 @@ class EWPProject (object):
|
||||
self.project['incs'].append(d.text)
|
||||
|
||||
for i in range(0, len(self.project['incs'])):
|
||||
|
||||
s = str(self.project['incs'][i])
|
||||
|
||||
if os.path.sep not in s:
|
||||
if os.path.sep == '\\':
|
||||
s = s.replace('/','\\')
|
||||
s = s.replace('/', '\\')
|
||||
elif os.path.sep == '/':
|
||||
s = s.replace('\\','/')
|
||||
s = s.replace('\\', '/')
|
||||
|
||||
self.project['incs'][i] = s.replace('$PROJ_DIR$'+os.path.sep+'..', self.path)
|
||||
|
||||
self.project['files']=[]
|
||||
i=0
|
||||
self.project['files'] = []
|
||||
i = 0
|
||||
|
||||
if os.path.exists(self.path + '/Drivers/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc'):
|
||||
for entry in os.listdir(self.path + '/Drivers/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc'):
|
||||
@ -64,32 +66,35 @@ class EWPProject (object):
|
||||
self.project['files'].append(self.path + '/Drivers/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/'+entry)
|
||||
|
||||
def displaySummary(self):
|
||||
|
||||
print ('Project Name:' + self.project['name'])
|
||||
print ('Project chip:' + self.project['chip'])
|
||||
print ('Project includes: ' + ' '.join(self.project['incs']))
|
||||
print ('Project defines: ' + ' '.join(self.project['defs']))
|
||||
print ('Project srcs: ' + ' '.join(self.project['srcs']))
|
||||
""" Display summary of parsed project settings
|
||||
"""
|
||||
print('Project Name:' + self.project['name'])
|
||||
print('Project chip:' + self.project['chip'])
|
||||
print('Project includes: ' + ' '.join(self.project['incs']))
|
||||
print('Project defines: ' + ' '.join(self.project['defs']))
|
||||
print('Project srcs: ' + ' '.join(self.project['srcs']))
|
||||
|
||||
def searchGroups(self, xml, sources):
|
||||
|
||||
""" Display summary of parsed project settings
|
||||
@param xml XML file with project settings configuration
|
||||
@param sources List containing source files
|
||||
"""
|
||||
for element in xml.getchildren():
|
||||
|
||||
if element.tag == 'group':
|
||||
self.searchGroups(element,sources)
|
||||
|
||||
self.searchGroups(element, sources)
|
||||
elif element.tag == 'file':
|
||||
if not str(element.name).endswith('.s'):
|
||||
|
||||
s = str(element.name)
|
||||
if os.path.sep not in s:
|
||||
if os.path.sep == '\\':
|
||||
s = s.replace('/','\\')
|
||||
s = s.replace('/', '\\')
|
||||
elif os.path.sep == '/':
|
||||
s = s.replace('\\','/')
|
||||
s = s.replace('\\', '/')
|
||||
|
||||
sources.append(s.replace('$PROJ_DIR$'+os.path.sep+'..', self.path))
|
||||
|
||||
def getProject(self):
|
||||
|
||||
""" Return parsed project settings stored as dictionary
|
||||
@return Dictionary containing project settings
|
||||
"""
|
||||
return self.project
|
||||
Loading…
x
Reference in New Issue
Block a user