SConscript revision 9850
14762Snate@binkert.org# -*- mode:python -*- 24762Snate@binkert.org 34762Snate@binkert.org# Copyright (c) 2009 The Hewlett-Packard Development Company 44762Snate@binkert.org# All rights reserved. 54762Snate@binkert.org# 64762Snate@binkert.org# Redistribution and use in source and binary forms, with or without 74762Snate@binkert.org# modification, are permitted provided that the following conditions are 84762Snate@binkert.org# met: redistributions of source code must retain the above copyright 94762Snate@binkert.org# notice, this list of conditions and the following disclaimer; 104762Snate@binkert.org# redistributions in binary form must reproduce the above copyright 114762Snate@binkert.org# notice, this list of conditions and the following disclaimer in the 124762Snate@binkert.org# documentation and/or other materials provided with the distribution; 134762Snate@binkert.org# neither the name of the copyright holders nor the names of its 144762Snate@binkert.org# contributors may be used to endorse or promote products derived from 154762Snate@binkert.org# this software without specific prior written permission. 164762Snate@binkert.org# 174762Snate@binkert.org# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 184762Snate@binkert.org# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 194762Snate@binkert.org# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 204762Snate@binkert.org# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 214762Snate@binkert.org# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 224762Snate@binkert.org# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 234762Snate@binkert.org# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 244762Snate@binkert.org# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 254762Snate@binkert.org# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 264762Snate@binkert.org# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 274762Snate@binkert.org# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 284762Snate@binkert.org# 294762Snate@binkert.org# Authors: Nathan Binkert 304762Snate@binkert.org 314762Snate@binkert.orgimport os 324762Snate@binkert.orgimport re 334762Snate@binkert.orgimport sys 344762Snate@binkert.org 35from os.path import isdir, isfile, join as joinpath 36 37from SCons.Scanner import Classic 38 39Import('*') 40 41if env['PROTOCOL'] == 'None': 42 Return() 43 44output_dir = Dir('.') 45html_dir = Dir('html') 46slicc_dir = Dir('../slicc') 47 48sys.path[1:1] = [ Dir('..').srcnode().abspath ] 49from slicc.parser import SLICC 50 51slicc_depends = [] 52for root,dirs,files in os.walk(slicc_dir.srcnode().abspath): 53 for f in files: 54 if f.endswith('.py'): 55 slicc_depends.append(File(joinpath(root, f))) 56 57# 58# Use SLICC 59# 60env["SLICC_PATH"] = protocol_dirs 61slicc_scanner = Classic("SliccScanner", ['.sm', '.slicc'], "SLICC_PATH", 62 r'''include[ \t]["'](.*)["'];''') 63env.Append(SCANNERS=slicc_scanner) 64 65def slicc_emitter(target, source, env): 66 assert len(source) == 1 67 filepath = source[0].srcnode().abspath 68 69 slicc = SLICC(filepath, protocol_base.abspath, verbose=False) 70 slicc.process() 71 slicc.writeCodeFiles(output_dir.abspath, slicc_includes) 72 if env['SLICC_HTML']: 73 slicc.writeHTMLFiles(html_dir.abspath) 74 75 target.extend([output_dir.File(f) for f in sorted(slicc.files())]) 76 return target, source 77 78def slicc_action(target, source, env): 79 assert len(source) == 1 80 filepath = source[0].srcnode().abspath 81 82 slicc = SLICC(filepath, protocol_base.abspath, verbose=True) 83 slicc.process() 84 slicc.writeCodeFiles(output_dir.abspath, slicc_includes) 85 if env['SLICC_HTML']: 86 slicc.writeHTMLFiles(html_dir.abspath) 87 88slicc_builder = Builder(action=MakeAction(slicc_action, Transform("SLICC")), 89 emitter=slicc_emitter) 90 91protocol = env['PROTOCOL'] 92protocol_dir = None 93for path in protocol_dirs: 94 if os.path.exists(os.path.join(path, "%s.slicc" % protocol)): 95 protocol_dir = Dir(path) 96 break 97 98if not protocol_dir: 99 raise ValueError, "Could not find %s.slicc in protocol_dirs" % protocol 100 101sources = [ protocol_dir.File("%s.slicc" % protocol) ] 102 103env.Append(BUILDERS={'SLICC' : slicc_builder}) 104nodes = env.SLICC([], sources) 105env.Depends(nodes, slicc_depends) 106 107for f in nodes: 108 s = str(f) 109 if s.endswith('.cc'): 110 Source(f) 111 elif s.endswith('.py'): 112 SimObject(f) 113 114