Martin Storsjo 518b6c9882 [llvm-rc] Handle C preprocessor output
When preprocessing resource scripts (which can easily be done outside
of llvm-rc), included headers can leave behind C declarations (despite
preprocessing with -DRC_INVOKED), that can't be parsed by a resource
compiler.

This is handled in all of rc.exe, by parsing the preprocessor output
line markers and ignoring content from files named *.h and *.c,
documented at [1].

In addition to this filtering, strip out any other preprocessor directive
that is left behind (like pragmas) which also can't be handled by the
tokenizer.

The added test uses both standard #line markers (supported by rc.exe) and
GNU style extended line markers, thus this test doesn't pass with rc.exe,
but passes with GNU windres. (Windres on the other hand doesn't filter
out files named *.c, only *.h.)

Differential Revision: https://reviews.llvm.org/D46579

[1] https://msdn.microsoft.com/en-us/library/windows/desktop/aa381033(v=vs.85).aspx

llvm-svn: 331903
2018-05-09 18:21:03 +00:00

29 lines
646 B
Plaintext

// Test that the input originally is included.
STRINGTABLE {
1 "a"
}
#line 2 "cpp-source.rc"
// Content from a rc file (potentially the source file itself) is included.
STRINGTABLE {
2 "b"
}
// Test a preprocessing directive that starts with leading whitespace.
#line 1 "\\some\\path\\header.h"
// Content from .h files is ignored.
typedef int Foo;
#line 123 "\\some\\path\\header.h"
void someFunc(void);
// Check GNU style line markers.
# 4 "cpp-source.rc" 1
STRINGTABLE {
3 "c"
}
# 1 "other/header.h" 1
typedef int Bar;
# 10 "cpp-source.rc" 2
// Test that other preprocessor directives are ignored.
#pragma foo
STRINGTABLE {
4 "d"
}