mirror of
https://gitlab.com/ita1024/waf.git
synced 2025-01-07 08:55:31 +01:00
Issue 1186
This commit is contained in:
parent
2072e65e6f
commit
fb0f6ed5ea
@ -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):
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user