org.eclipse.jdt.internal.compiler.ast.StringLiteral Maven / Gradle / Ivy
/*******************************************************************************
* Copyright (c) 2000, 2009 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.jdt.internal.compiler.ast;
import org.eclipse.jdt.internal.compiler.ASTVisitor;
import org.eclipse.jdt.internal.compiler.codegen.CodeStream;
import org.eclipse.jdt.internal.compiler.impl.StringConstant;
import org.eclipse.jdt.internal.compiler.lookup.BlockScope;
import org.eclipse.jdt.internal.compiler.lookup.TypeBinding;
public class StringLiteral extends Literal {
char[] source;
int lineNumber;
public StringLiteral(char[] token, int start, int end, int lineNumber) {
this(start,end);
this.source = token;
this.lineNumber = lineNumber - 1; // line number is 1 based
}
public StringLiteral(int s, int e) {
super(s,e);
}
public void computeConstant() {
this.constant = StringConstant.fromValue(String.valueOf(this.source));
}
public ExtendedStringLiteral extendWith(CharLiteral lit){
//add the lit source to mine, just as if it was mine
return new ExtendedStringLiteral(this,lit);
}
public ExtendedStringLiteral extendWith(StringLiteral lit){
//add the lit source to mine, just as if it was mine
return new ExtendedStringLiteral(this,lit);
}
/**
* Add the lit source to mine, just as if it was mine
*/
public StringLiteralConcatenation extendsWith(StringLiteral lit) {
return new StringLiteralConcatenation(this, lit);
}
/**
* Code generation for string literal
*/
public void generateCode(BlockScope currentScope, CodeStream codeStream, boolean valueRequired) {
int pc = codeStream.position;
if (valueRequired)
codeStream.ldc(this.constant.stringValue());
codeStream.recordPositionsFrom(pc, this.sourceStart);
}
public TypeBinding literalType(BlockScope scope) {
return scope.getJavaLangString();
}
public StringBuffer printExpression(int indent, StringBuffer output) {
// handle some special char.....
output.append('\"');
for (int i = 0; i < this.source.length; i++) {
switch (this.source[i]) {
case '\b' :
output.append("\\b"); //$NON-NLS-1$
break;
case '\t' :
output.append("\\t"); //$NON-NLS-1$
break;
case '\n' :
output.append("\\n"); //$NON-NLS-1$
break;
case '\f' :
output.append("\\f"); //$NON-NLS-1$
break;
case '\r' :
output.append("\\r"); //$NON-NLS-1$
break;
case '\"' :
output.append("\\\""); //$NON-NLS-1$
break;
case '\'' :
output.append("\\'"); //$NON-NLS-1$
break;
case '\\' : //take care not to display the escape as a potential real char
output.append("\\\\"); //$NON-NLS-1$
break;
default :
output.append(this.source[i]);
}
}
output.append('\"');
return output;
}
public char[] source() {
return this.source;
}
public void traverse(ASTVisitor visitor, BlockScope scope) {
visitor.visit(this, scope);
visitor.endVisit(this, scope);
}
}