forked from jasder/antlr
Fixed warning in C++ code generation and remove obsolete file.
This commit is contained in:
parent
4a6b68c6f6
commit
b8867c732d
|
@ -241,8 +241,7 @@ bool <r.name>Sempred(Ref\<<r.ctxType>\> _localctx, int predicateIndex);
|
||||||
>>
|
>>
|
||||||
|
|
||||||
RuleSempredFunction(r, actions) ::= <<
|
RuleSempredFunction(r, actions) ::= <<
|
||||||
<! Called for both lexer and parser. But only one of them is actually available. !>
|
bool <r.factory.grammar.name>::<r.name>Sempred(Ref\<<r.ctxType>\> _localctx, int predicateIndex) {
|
||||||
bool <if (parser)><parser.name><else><lexer.name><endif>::<r.name>Sempred(Ref\<<r.ctxType>\> _localctx, int predicateIndex) {
|
|
||||||
switch (predicateIndex) {
|
switch (predicateIndex) {
|
||||||
<actions: {index | case <index>: return <actions.(index)>}; separator="\n">
|
<actions: {index | case <index>: return <actions.(index)>}; separator="\n">
|
||||||
|
|
||||||
|
|
|
@ -1,244 +0,0 @@
|
||||||
/*
|
|
||||||
* [The "BSD license"]
|
|
||||||
* Copyright (c) 2016 David Sisson, Mike Lischke
|
|
||||||
* Copyright (c) 2012 Terence Parr
|
|
||||||
* Copyright (c) 2012 Sam Harwell
|
|
||||||
* All rights reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
*
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
* 3. The name of the author may not be used to endorse or promote products
|
|
||||||
* derived from this software without specific prior written permission.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
||||||
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
||||||
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
||||||
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
||||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
||||||
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
||||||
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.antlr.v4.codegen;
|
|
||||||
|
|
||||||
import org.antlr.v4.codegen.CodeGenerator;
|
|
||||||
import org.antlr.v4.codegen.Target;
|
|
||||||
import org.antlr.v4.tool.ErrorType;
|
|
||||||
import org.antlr.v4.tool.Grammar;
|
|
||||||
import org.antlr.v4.tool.ast.GrammarAST;
|
|
||||||
import org.stringtemplate.v4.NumberRenderer;
|
|
||||||
import org.stringtemplate.v4.STErrorListener;
|
|
||||||
import org.stringtemplate.v4.ST;
|
|
||||||
import org.stringtemplate.v4.STGroup;
|
|
||||||
import org.stringtemplate.v4.STGroupFile;
|
|
||||||
import org.stringtemplate.v4.StringRenderer;
|
|
||||||
import org.stringtemplate.v4.misc.STMessage;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
public class CppTarget extends Target {
|
|
||||||
|
|
||||||
protected static final String[] cppKeywords = {
|
|
||||||
"alignas", "alignof", "and", "and_eq", "asm", "auto", "bitand",
|
|
||||||
"bitor", "bool", "break", "case", "catch", "char", "char16_t",
|
|
||||||
"char32_t", "class", "compl", "concept", "const", "constexpr",
|
|
||||||
"const_cast", "continue", "decltype", "default", "delete", "do",
|
|
||||||
"double", "dynamic_cast", "else", "enum", "explicit", "export",
|
|
||||||
"extern", "false", "float", "for", "friend", "goto", "if",
|
|
||||||
"inline", "int", "long", "mutable", "namespace", "new",
|
|
||||||
"noexcept", "not", "not_eq", "nullptr", "operator", "or",
|
|
||||||
"or_eq", "private", "protected", "public", "register",
|
|
||||||
"reinterpret_cast", "requires", "return", "short", "signed",
|
|
||||||
"sizeof", "static", "static_assert", "static_cast", "struct",
|
|
||||||
"switch", "template", "this", "thread_local", "throw", "true",
|
|
||||||
"try", "typedef", "typeid", "typename", "union", "unsigned",
|
|
||||||
"using", "virtual", "void", "volatile", "wchar_t", "while",
|
|
||||||
"xor", "xor_eq"
|
|
||||||
};
|
|
||||||
|
|
||||||
/** Avoid grammar symbols in this set to prevent conflicts in gen'd code. */
|
|
||||||
protected final Set<String> badWords = new HashSet<String>();
|
|
||||||
|
|
||||||
public CppTarget(CodeGenerator gen) {
|
|
||||||
super(gen, "Cpp");
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getVersion() {
|
|
||||||
return "4.5.2";
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean needsHeader() { return true; }
|
|
||||||
|
|
||||||
public Set<String> getBadWords() {
|
|
||||||
if (badWords.isEmpty()) {
|
|
||||||
addBadWords();
|
|
||||||
}
|
|
||||||
|
|
||||||
return badWords;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void addBadWords() {
|
|
||||||
badWords.addAll(Arrays.asList(cppKeywords));
|
|
||||||
badWords.add("rule");
|
|
||||||
badWords.add("parserRule");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@inheritDoc}
|
|
||||||
* <p/>
|
|
||||||
* For C++, this is the translation {@code 'a\n"'} → {@code "a\n\""}.
|
|
||||||
* Expect single quotes around the incoming literal. Just flip the quotes
|
|
||||||
* and replace double quotes with {@code \"}.
|
|
||||||
* <p/>
|
|
||||||
* Note that we have decided to allow people to use '\"' without penalty, so
|
|
||||||
* we must build the target string in a loop as {@link String#replace}
|
|
||||||
* cannot handle both {@code \"} and {@code "} without a lot of messing
|
|
||||||
* around.
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String getTargetStringLiteralFromANTLRStringLiteral(
|
|
||||||
CodeGenerator generator,
|
|
||||||
String literal, boolean addQuotes)
|
|
||||||
{
|
|
||||||
StringBuilder sb = new StringBuilder();
|
|
||||||
String is = literal;
|
|
||||||
|
|
||||||
if ( addQuotes ) sb.append('"');
|
|
||||||
|
|
||||||
for (int i = 1; i < is.length() -1; i++) {
|
|
||||||
if (is.charAt(i) == '\\') {
|
|
||||||
// Anything escaped is what it is! We assume that
|
|
||||||
// people know how to escape characters correctly. However
|
|
||||||
// we catch anything that does not need an escape in Java (which
|
|
||||||
// is what the default implementation is dealing with and remove
|
|
||||||
// the escape. The C target does this for instance.
|
|
||||||
//
|
|
||||||
switch (is.charAt(i+1)) {
|
|
||||||
// Pass through any escapes that Java also needs
|
|
||||||
//
|
|
||||||
case '"':
|
|
||||||
case 'n':
|
|
||||||
case 'r':
|
|
||||||
case 't':
|
|
||||||
case 'b':
|
|
||||||
case 'f':
|
|
||||||
case '\\':
|
|
||||||
// Pass the escape through
|
|
||||||
sb.append('\\');
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'u': // Assume unnnn
|
|
||||||
// Pass the escape through as double \\
|
|
||||||
// so that Java leaves as \u0000 string not char
|
|
||||||
sb.append('\\');
|
|
||||||
sb.append('\\');
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
// Remove the escape by virtue of not adding it here
|
|
||||||
// Thus \' becomes ' and so on
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Go past the \ character
|
|
||||||
i++;
|
|
||||||
} else {
|
|
||||||
// Characters that don't need \ in ANTLR 'strings' but do in Java
|
|
||||||
if (is.charAt(i) == '"') {
|
|
||||||
// We need to escape " in Java
|
|
||||||
sb.append('\\');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Add in the next character, which may have been escaped
|
|
||||||
sb.append(is.charAt(i));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( addQuotes ) sb.append('"');
|
|
||||||
|
|
||||||
return sb.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String encodeIntAsCharEscape(int v) {
|
|
||||||
if (v < Character.MIN_VALUE || v > Character.MAX_VALUE) {
|
|
||||||
throw new IllegalArgumentException(String.format("Cannot encode the specified value: %d", v));
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
if (v >= 0 && v < targetCharValueEscape.length && targetCharValueEscape[v] != null) {
|
|
||||||
return targetCharValueEscape[v];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (v >= 0x20 && v < 127 && (!Character.isDigit(v) || v == '8' || v == '9')) {
|
|
||||||
return String.valueOf((char)v);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( v>=0 && v<=127 ) {
|
|
||||||
String oct = Integer.toOctalString(v);
|
|
||||||
return "\\"+ oct;
|
|
||||||
}
|
|
||||||
|
|
||||||
String hex = Integer.toHexString(v | 0x10000).substring(1, 5);
|
|
||||||
return "\\u" + hex;
|
|
||||||
*/
|
|
||||||
return "0x" + Integer.toHexString(v) + ", ";
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getSerializedATNSegmentLimit() {
|
|
||||||
// 65535 is the class file format byte limit for a UTF-8 encoded string literal
|
|
||||||
// 3 is the maximum number of bytes it takes to encode a value in the range 0-0xFFFF
|
|
||||||
return 65535 / 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected boolean visibleGrammarSymbolCausesIssueInGeneratedCode(GrammarAST idNode) {
|
|
||||||
return getBadWords().contains(idNode.getText());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected STGroup loadTemplates() {
|
|
||||||
STGroup result = super.loadTemplates();
|
|
||||||
result.registerRenderer(Integer.class, new NumberRenderer());
|
|
||||||
result.registerRenderer(String.class, new StringRenderer());
|
|
||||||
result.setListener(new STErrorListener() {
|
|
||||||
@Override
|
|
||||||
public void compileTimeError(STMessage msg) {
|
|
||||||
reportError(msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void runTimeError(STMessage msg) {
|
|
||||||
reportError(msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void IOError(STMessage msg) {
|
|
||||||
reportError(msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void internalError(STMessage msg) {
|
|
||||||
reportError(msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void reportError(STMessage msg) {
|
|
||||||
getCodeGenerator().tool.errMgr.toolError(ErrorType.STRING_TEMPLATE_WARNING, msg.cause, msg.toString());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue