[llvm-commits] [llvm] r121273 - /llvm/trunk/utils/TableGen/TGLexer.cpp
Bill Wendling
isanbard at gmail.com
Wed Dec 8 12:02:49 PST 2010
Author: void
Date: Wed Dec 8 14:02:49 2010
New Revision: 121273
URL: http://llvm.org/viewvc/llvm-project?rev=121273&view=rev
Log:
Use this new fangled StringSwitch technology.
Modified:
llvm/trunk/utils/TableGen/TGLexer.cpp
Modified: llvm/trunk/utils/TableGen/TGLexer.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/utils/TableGen/TGLexer.cpp?rev=121273&r1=121272&r2=121273&view=diff
==============================================================================
--- llvm/trunk/utils/TableGen/TGLexer.cpp (original)
+++ llvm/trunk/utils/TableGen/TGLexer.cpp Wed Dec 8 14:02:49 2010
@@ -12,10 +12,11 @@
//===----------------------------------------------------------------------===//
#include "TGLexer.h"
-#include "llvm/ADT/Twine.h"
#include "llvm/Support/SourceMgr.h"
#include "llvm/Support/MemoryBuffer.h"
#include "llvm/Config/config.h"
+#include "llvm/ADT/StringSwitch.h"
+#include "llvm/ADT/Twine.h"
#include <cctype>
#include <cstdio>
#include <cstdlib>
@@ -419,36 +420,23 @@
++CurPtr;
// Check to see which operator this is.
- switch (CurPtr - Start) {
- default:
- break;
- case 2:
- if (!memcmp(Start, "eq", 2)) return tgtok::XEq;
- if (!memcmp(Start, "if", 2)) return tgtok::XIf;
- break;
- case 3:
- if (!memcmp(Start, "car", 3)) return tgtok::XCar;
- if (!memcmp(Start, "cdr", 3)) return tgtok::XCdr;
- if (!memcmp(Start, "con", 3)) return tgtok::XConcat;
- if (!memcmp(Start, "shl", 3)) return tgtok::XSHL;
- if (!memcmp(Start, "sra", 3)) return tgtok::XSRA;
- if (!memcmp(Start, "srl", 3)) return tgtok::XSRL;
- break;
- case 4:
- if (!memcmp(Start, "cast", 4)) return tgtok::XCast;
- if (!memcmp(Start, "null", 4)) return tgtok::XNull;
- break;
- case 5:
- if (!memcmp(Start, "subst", 5)) return tgtok::XSubst;
- break;
- case 7:
- if (!memcmp(Start, "foreach", 7)) return tgtok::XForEach;
- break;
- case 9:
- if (!memcmp(Start, "strconcat", 9)) return tgtok::XStrConcat;
- break;
- }
+ tgtok::TokKind Kind =
+ StringSwitch<tgtok::TokKind>(StringRef(Start, CurPtr - Start))
+ .Case("eq", tgtok::XEq)
+ .Case("if", tgtok::XIf)
+ .Case("car", tgtok::XCar)
+ .Case("cdr", tgtok::XCdr)
+ .Case("con", tgtok::XConcat)
+ .Case("shl", tgtok::XSHL)
+ .Case("sra", tgtok::XSRA)
+ .Case("srl", tgtok::XSRL)
+ .Case("cast", tgtok::XCast)
+ .Case("null", tgtok::XNull)
+ .Case("subst", tgtok::XSubst)
+ .Case("foreach", tgtok::XForEach)
+ .Case("strconcat", tgtok::XStrConcat)
+ .Default(tgtok::Error);
- return ReturnError(Start - 1, "Unknown operator");
+ return Kind != tgtok::Error ? Kind : ReturnError(Start-1, "Unknown operator");
}
More information about the llvm-commits
mailing list