2
0
mirror of https://gitlab.com/ita1024/waf.git synced 2025-01-07 08:55:31 +01:00

Issue 1186

This commit is contained in:
Thomas Nagy 2012-08-05 01:33:11 +02:00
parent 2072e65e6f
commit fb0f6ed5ea
2 changed files with 66 additions and 3 deletions

View File

@ -26,8 +26,8 @@ A dumb preprocessor is also available in the tool *c_dumbpreproc*
""" """
# TODO: more varargs, pragma once # TODO: more varargs, pragma once
import re, sys, os, string, traceback import re, string, traceback
from waflib import Logs, Build, Utils, Errors from waflib import Logs, Utils, Errors
from waflib.Logs import debug, error from waflib.Logs import debug, error
class PreprocError(Errors.WafError): class PreprocError(Errors.WafError):

View File

@ -4,8 +4,10 @@
"Process *.rc* files for C/C++: X{.rc -> [.res|.rc.o]}" "Process *.rc* files for C/C++: X{.rc -> [.res|.rc.o]}"
from waflib import Task import re, traceback
from waflib import Task, Logs, Utils
from waflib.TaskGen import extension from waflib.TaskGen import extension
from waflib.Tools import c_preproc
@extension('.rc') @extension('.rc')
def rc_file(self, node): def rc_file(self, node):
@ -21,6 +23,56 @@ def rc_file(self, node):
except AttributeError: except AttributeError:
self.compiled_tasks = [rctask] self.compiled_tasks = [rctask]
re_lines = re.compile(
'(?:^[ \t]*(#|%:)[ \t]*(ifdef|ifndef|if|else|elif|endif|include|import|define|undef|pragma)[ \t]*(.*?)\s*$)|'\
'(?:^\w+[ \t]*(ICON|BITMAP|CURSOR|HTML|FONT|MESSAGETABLE|TYPELIB|REGISTRY|D3DFX)[ \t]*(.*?)\s*$)',
re.IGNORECASE | re.MULTILINE)
class rc_parser(c_preproc.c_parser):
def filter_comments(self, filepath):
code = Utils.readf(filepath)
if c_preproc.use_trigraphs:
for (a, b) in c_preproc.trig_def: code = code.split(a).join(b)
code = c_preproc.re_nl.sub('', code)
code = c_preproc.re_cpp.sub(c_preproc.repl, code)
ret = []
for m in re.finditer(re_lines, code):
if m.group(2):
ret.append((m.group(2), m.group(3)))
else:
ret.append(('include', m.group(5)))
return ret
def addlines(self, node):
self.currentnode_stack.append(node.parent)
filepath = node.abspath()
self.count_files += 1
if self.count_files > c_preproc.recursion_limit:
raise c_preproc.PreprocError("recursion limit exceeded")
pc = self.parse_cache
Logs.debug('preproc: reading file %r', filepath)
try:
lns = pc[filepath]
except KeyError:
pass
else:
self.lines.extend(lns)
return
try:
lines = self.filter_comments(filepath)
lines.append((c_preproc.POPFILE, ''))
lines.reverse()
pc[filepath] = lines
self.lines.extend(lines)
except IOError:
raise c_preproc.PreprocError("could not read the file %s" % filepath)
except Exception:
if Logs.verbose > 0:
Logs.error("parsing %s failed" % filepath)
traceback.print_exc()
class winrc(Task.Task): class winrc(Task.Task):
""" """
Task for compiling resource files Task for compiling resource files
@ -28,6 +80,17 @@ class winrc(Task.Task):
run_str = '${WINRC} ${WINRCFLAGS} ${CPPPATH_ST:INCPATHS} ${DEFINES_ST:DEFINES} ${WINRC_TGT_F} ${TGT} ${WINRC_SRC_F} ${SRC}' run_str = '${WINRC} ${WINRCFLAGS} ${CPPPATH_ST:INCPATHS} ${DEFINES_ST:DEFINES} ${WINRC_TGT_F} ${TGT} ${WINRC_SRC_F} ${SRC}'
color = 'BLUE' color = 'BLUE'
def scan(self):
tmp = rc_parser(self.generator.includes_nodes)
tmp.start(self.inputs[0], self.env)
nodes = tmp.nodes
names = tmp.names
if Logs.verbose:
Logs.debug('deps: deps for %s: %r; unresolved %r' % (str(self), nodes, names))
return (nodes, names)
def configure(conf): def configure(conf):
""" """
Detect the programs RC or windres, depending on the C/C++ compiler in use Detect the programs RC or windres, depending on the C/C++ compiler in use