diff options
author | Chris Lattner <sabre@nondot.org> | 2009-08-10 01:39:42 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-08-10 01:39:42 +0000 |
commit | ff4bc460c52c1f285d8a56da173641bf92d49e3f (patch) | |
tree | 7da0d5977dffaffaa4bb5da91039d0960f839f77 /tools/llvm-mc/AsmLexer.cpp | |
parent | e36df3fd31a08a41d9ad04fcba182b616b030c9c (diff) | |
download | external_llvm-ff4bc460c52c1f285d8a56da173641bf92d49e3f.zip external_llvm-ff4bc460c52c1f285d8a56da173641bf92d49e3f.tar.gz external_llvm-ff4bc460c52c1f285d8a56da173641bf92d49e3f.tar.bz2 |
Make the big switch: Change MCSectionMachO to represent a section *semantically*
instead of syntactically as a string. This means that it keeps track of the
segment, section, flags, etc directly and asmprints them in the right format.
This also includes parsing and validation support for llvm-mc and
"attribute(section)", so we should now start getting errors about invalid
section attributes from the compiler instead of the assembler on darwin.
Still todo:
1) Uniquing of darwin mcsections
2) Move all the Darwin stuff out to MCSectionMachO.[cpp|h]
3) there are a few FIXMEs, for example what is the syntax to get the
S_GB_ZEROFILL segment type?
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78547 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/llvm-mc/AsmLexer.cpp')
-rw-r--r-- | tools/llvm-mc/AsmLexer.cpp | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/tools/llvm-mc/AsmLexer.cpp b/tools/llvm-mc/AsmLexer.cpp index 28b0c1e..5b394b6 100644 --- a/tools/llvm-mc/AsmLexer.cpp +++ b/tools/llvm-mc/AsmLexer.cpp @@ -242,6 +242,17 @@ AsmToken AsmLexer::LexQuote() { return AsmToken(AsmToken::String, StringRef(TokStart, CurPtr - TokStart)); } +StringRef AsmLexer::LexUntilEndOfStatement() { + TokStart = CurPtr; + + while (*CurPtr != '#' && // Start of line comment. + *CurPtr != ';' && // End of statement marker. + *CurPtr != '\n' && + *CurPtr != '\r' && + (*CurPtr != 0 || CurPtr != CurBuf->getBufferEnd())) + ++CurPtr; + return StringRef(TokStart, CurPtr-TokStart); +} AsmToken AsmLexer::LexToken() { TokStart = CurPtr; |