Brian Daniels / mbed-tools

Fork of mbed-tools by Morpheus

Committer:
screamer
Date:
Wed Mar 30 16:23:44 2016 +0000
Revision:
0:4a2e5f0422d6
Child:
2:5f044fef8f98
Initial revision

Who changed what in which revision?

UserRevisionLine numberNew contents of line
screamer 0:4a2e5f0422d6 1 """
screamer 0:4a2e5f0422d6 2 mbed SDK
screamer 0:4a2e5f0422d6 3 Copyright (c) 2011-2015 ARM Limited
screamer 0:4a2e5f0422d6 4
screamer 0:4a2e5f0422d6 5 Licensed under the Apache License, Version 2.0 (the "License");
screamer 0:4a2e5f0422d6 6 you may not use this file except in compliance with the License.
screamer 0:4a2e5f0422d6 7 You may obtain a copy of the License at
screamer 0:4a2e5f0422d6 8
screamer 0:4a2e5f0422d6 9 http://www.apache.org/licenses/LICENSE-2.0
screamer 0:4a2e5f0422d6 10
screamer 0:4a2e5f0422d6 11 Unless required by applicable law or agreed to in writing, software
screamer 0:4a2e5f0422d6 12 distributed under the License is distributed on an "AS IS" BASIS,
screamer 0:4a2e5f0422d6 13 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
screamer 0:4a2e5f0422d6 14 See the License for the specific language governing permissions and
screamer 0:4a2e5f0422d6 15 limitations under the License.
screamer 0:4a2e5f0422d6 16 """
screamer 0:4a2e5f0422d6 17 import re
screamer 0:4a2e5f0422d6 18 import os
screamer 0:4a2e5f0422d6 19 from project_generator_definitions.definitions import ProGenDef
screamer 0:4a2e5f0422d6 20
screamer 0:4a2e5f0422d6 21 from workspace_tools.export.exporters import Exporter
screamer 0:4a2e5f0422d6 22 from workspace_tools.targets import TARGET_MAP, TARGET_NAMES
screamer 0:4a2e5f0422d6 23
screamer 0:4a2e5f0422d6 24 # If you wish to add a new target, add it to project_generator_definitions, and then
screamer 0:4a2e5f0422d6 25 # define progen_target name in the target class (`` self.progen_target = 'my_target_name' ``)
screamer 0:4a2e5f0422d6 26 class IAREmbeddedWorkbench(Exporter):
screamer 0:4a2e5f0422d6 27 """
screamer 0:4a2e5f0422d6 28 Exporter class for IAR Systems. This class uses project generator.
screamer 0:4a2e5f0422d6 29 """
screamer 0:4a2e5f0422d6 30 # These 2 are currently for exporters backward compatiblity
screamer 0:4a2e5f0422d6 31 NAME = 'IAR'
screamer 0:4a2e5f0422d6 32 TOOLCHAIN = 'IAR'
screamer 0:4a2e5f0422d6 33 # PROGEN_ACTIVE contains information for exporter scripts that this is using progen
screamer 0:4a2e5f0422d6 34 PROGEN_ACTIVE = True
screamer 0:4a2e5f0422d6 35
screamer 0:4a2e5f0422d6 36 # backward compatibility with our scripts
screamer 0:4a2e5f0422d6 37 TARGETS = []
screamer 0:4a2e5f0422d6 38 for target in TARGET_NAMES:
screamer 0:4a2e5f0422d6 39 try:
screamer 0:4a2e5f0422d6 40 if (ProGenDef('iar').is_supported(str(TARGET_MAP[target])) or
screamer 0:4a2e5f0422d6 41 ProGenDef('iar').is_supported(TARGET_MAP[target].progen['target'])):
screamer 0:4a2e5f0422d6 42 TARGETS.append(target)
screamer 0:4a2e5f0422d6 43 except AttributeError:
screamer 0:4a2e5f0422d6 44 # target is not supported yet
screamer 0:4a2e5f0422d6 45 continue
screamer 0:4a2e5f0422d6 46
screamer 0:4a2e5f0422d6 47 def generate(self):
screamer 0:4a2e5f0422d6 48 """ Generates the project files """
screamer 0:4a2e5f0422d6 49 project_data = self.progen_get_project_data()
screamer 0:4a2e5f0422d6 50 tool_specific = {}
screamer 0:4a2e5f0422d6 51 # Expand tool specific settings by IAR specific settings which are required
screamer 0:4a2e5f0422d6 52 try:
screamer 0:4a2e5f0422d6 53 if TARGET_MAP[self.target].progen['iar']['template']:
screamer 0:4a2e5f0422d6 54 tool_specific['iar'] = TARGET_MAP[self.target].progen['iar']
screamer 0:4a2e5f0422d6 55 except KeyError:
screamer 0:4a2e5f0422d6 56 # use default template
screamer 0:4a2e5f0422d6 57 # by the mbed projects
screamer 0:4a2e5f0422d6 58 tool_specific['iar'] = {
screamer 0:4a2e5f0422d6 59 # We currently don't use misc, template sets those for us
screamer 0:4a2e5f0422d6 60 # 'misc': {
screamer 0:4a2e5f0422d6 61 # 'cxx_flags': ['--no_rtti', '--no_exceptions'],
screamer 0:4a2e5f0422d6 62 # 'c_flags': ['--diag_suppress=Pa050,Pa084,Pa093,Pa082'],
screamer 0:4a2e5f0422d6 63 # 'ld_flags': ['--skip_dynamic_initialization'],
screamer 0:4a2e5f0422d6 64 # },
screamer 0:4a2e5f0422d6 65 'template': [os.path.join(os.path.dirname(__file__), 'iar_template.ewp.tmpl')],
screamer 0:4a2e5f0422d6 66 }
screamer 0:4a2e5f0422d6 67
screamer 0:4a2e5f0422d6 68 project_data['tool_specific'] = {}
screamer 0:4a2e5f0422d6 69 project_data['tool_specific'].update(tool_specific)
screamer 0:4a2e5f0422d6 70 self.progen_gen_file('iar_arm', project_data)
screamer 0:4a2e5f0422d6 71
screamer 0:4a2e5f0422d6 72 # Currently not used, we should reuse folder_name to create virtual folders
screamer 0:4a2e5f0422d6 73 class IarFolder():
screamer 0:4a2e5f0422d6 74 """
screamer 0:4a2e5f0422d6 75 This is a recursive folder object.
screamer 0:4a2e5f0422d6 76 To present the folder structure in the IDE as it is presented on the disk.
screamer 0:4a2e5f0422d6 77 This can be used for uvision as well if you replace the __str__ method.
screamer 0:4a2e5f0422d6 78 Example:
screamer 0:4a2e5f0422d6 79 files: ./main.cpp, ./apis/I2C.h, ./mbed/common/I2C.cpp
screamer 0:4a2e5f0422d6 80 in the project this would look like:
screamer 0:4a2e5f0422d6 81 main.cpp
screamer 0:4a2e5f0422d6 82 common/I2C.cpp
screamer 0:4a2e5f0422d6 83 input:
screamer 0:4a2e5f0422d6 84 folder_level : folder path to current folder
screamer 0:4a2e5f0422d6 85 folder_name : name of current folder
screamer 0:4a2e5f0422d6 86 source_files : list of source_files (all must be in same directory)
screamer 0:4a2e5f0422d6 87 """
screamer 0:4a2e5f0422d6 88 def __init__(self, folder_level, folder_name, source_files):
screamer 0:4a2e5f0422d6 89 self.folder_level = folder_level
screamer 0:4a2e5f0422d6 90 self.folder_name = folder_name
screamer 0:4a2e5f0422d6 91 self.source_files = source_files
screamer 0:4a2e5f0422d6 92 self.sub_folders = {}
screamer 0:4a2e5f0422d6 93
screamer 0:4a2e5f0422d6 94 def __str__(self):
screamer 0:4a2e5f0422d6 95 """
screamer 0:4a2e5f0422d6 96 converts the folder structue to IAR project format.
screamer 0:4a2e5f0422d6 97 """
screamer 0:4a2e5f0422d6 98 group_start = ""
screamer 0:4a2e5f0422d6 99 group_end = ""
screamer 0:4a2e5f0422d6 100 if self.folder_name != "":
screamer 0:4a2e5f0422d6 101 group_start = "<group>\n<name>%s</name>\n" %(self.folder_name)
screamer 0:4a2e5f0422d6 102 group_end = "</group>\n"
screamer 0:4a2e5f0422d6 103
screamer 0:4a2e5f0422d6 104 str_content = group_start
screamer 0:4a2e5f0422d6 105 #Add files in current folder
screamer 0:4a2e5f0422d6 106 if self.source_files:
screamer 0:4a2e5f0422d6 107 for src in self.source_files:
screamer 0:4a2e5f0422d6 108 str_content += "<file>\n<name>$PROJ_DIR$/%s</name>\n</file>\n" % src
screamer 0:4a2e5f0422d6 109 #Add sub folders
screamer 0:4a2e5f0422d6 110 if self.sub_folders:
screamer 0:4a2e5f0422d6 111 for folder_name in self.sub_folders.iterkeys():
screamer 0:4a2e5f0422d6 112 str_content += self.sub_folders[folder_name].__str__()
screamer 0:4a2e5f0422d6 113
screamer 0:4a2e5f0422d6 114 str_content += group_end
screamer 0:4a2e5f0422d6 115 return str_content
screamer 0:4a2e5f0422d6 116
screamer 0:4a2e5f0422d6 117 def insert_file(self, source_input):
screamer 0:4a2e5f0422d6 118 """
screamer 0:4a2e5f0422d6 119 Inserts a source file into the folder tree
screamer 0:4a2e5f0422d6 120 """
screamer 0:4a2e5f0422d6 121 if self.source_files:
screamer 0:4a2e5f0422d6 122 #All source_files in a IarFolder must be in same directory.
screamer 0:4a2e5f0422d6 123 dir_sources = IarFolder.get_directory(self.source_files[0])
screamer 0:4a2e5f0422d6 124 #Check if sources are already at their deepest level.
screamer 0:4a2e5f0422d6 125 if not self.folder_level == dir_sources:
screamer 0:4a2e5f0422d6 126 _reg_exp = r"^" + re.escape(self.folder_level) + r"[/\\]?([^/\\]+)"
screamer 0:4a2e5f0422d6 127 folder_name = re.match(_reg_exp, dir_sources).group(1)
screamer 0:4a2e5f0422d6 128 self.sub_folders[folder_name] = IarFolder(os.path.join(self.folder_level, folder_name), folder_name, self.source_files)
screamer 0:4a2e5f0422d6 129 self.source_files = []
screamer 0:4a2e5f0422d6 130
screamer 0:4a2e5f0422d6 131 dir_input = IarFolder.get_directory(source_input)
screamer 0:4a2e5f0422d6 132 if dir_input == self.folder_level:
screamer 0:4a2e5f0422d6 133 self.source_files.append(source_input)
screamer 0:4a2e5f0422d6 134 else:
screamer 0:4a2e5f0422d6 135 _reg_exp = r"^" + re.escape(self.folder_level) + r"[/\\]?([^/\\]+)"
screamer 0:4a2e5f0422d6 136 folder_name = re.match(_reg_exp, dir_input).group(1)
screamer 0:4a2e5f0422d6 137 if self.sub_folders.has_key(folder_name):
screamer 0:4a2e5f0422d6 138 self.sub_folders[folder_name].insert_file(source_input)
screamer 0:4a2e5f0422d6 139 else:
screamer 0:4a2e5f0422d6 140 if self.folder_level == "":
screamer 0:4a2e5f0422d6 141 #Top level exception
screamer 0:4a2e5f0422d6 142 self.sub_folders[folder_name] = IarFolder(folder_name, folder_name, [source_input])
screamer 0:4a2e5f0422d6 143 else:
screamer 0:4a2e5f0422d6 144 self.sub_folders[folder_name] = IarFolder(os.path.join(self.folder_level, folder_name), folder_name, [source_input])
screamer 0:4a2e5f0422d6 145
screamer 0:4a2e5f0422d6 146 @staticmethod
screamer 0:4a2e5f0422d6 147 def get_directory(file_path):
screamer 0:4a2e5f0422d6 148 """
screamer 0:4a2e5f0422d6 149 Returns the directory of the file
screamer 0:4a2e5f0422d6 150 """
screamer 0:4a2e5f0422d6 151 return os.path.dirname(file_path)