All Downloads are FREE. Search and download functionalities are using the official Maven repository.

manifold.preprocessor.statement.Statement Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2019 - Manifold Systems LLC
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *       http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package manifold.preprocessor.statement;

import java.util.List;
import manifold.preprocessor.definitions.Definitions;
import manifold.preprocessor.TokenType;

public abstract class Statement
{
  private final TokenType _tokenType;
  private final int _tokenStart;
  private final int _tokenEnd;

  public Statement( TokenType tokenType, int start, int end )
  {
    _tokenType = tokenType;
    _tokenStart = start;
    _tokenEnd = end;
  }

  public TokenType getTokenType()
  {
    return _tokenType;
  }

  public int getTokenStart()
  {
    return _tokenStart;
  }

  public int getTokenEnd()
  {
    return _tokenEnd;
  }

  /**
   * See {@link #preserveMaskedOutSpace(StringBuilder, CharSequence, int, int)}
   */
  protected void preserveMaskedOutSpace( StringBuilder result, CharSequence source )
  {
    preserveMaskedOutSpace( result, source, getTokenStart(), getTokenEnd() );
  }
  /**
   * Replaces preprocessor directives and masked out source with whitespace. Retains newline characters.
   * 

* Note, a more efficient approach would involve only preserving newline chars for debug purposes and omitting * masked out source. However, since javac determines compile error line numbers from the error offset into the * original file, we must preserve the full length and structure of the original source. * * @param result The resulting preprocessed source. * @param source The original source. */ protected void preserveMaskedOutSpace( StringBuilder result, CharSequence source, int tokenStart, int tokenEnd ) { for( int i = tokenStart; i < tokenEnd; i++ ) { char c = source.charAt( i ); if( c == '\r' || c == '\n' || c == '\f' ) { result.append( c ); } else { result.append( ' ' ); } } } public abstract void execute( StringBuilder result, CharSequence source, boolean visible, Definitions definitions ); public abstract void execute( List result, boolean visible, Definitions definitions ); public abstract boolean hasPreprocessorDirectives(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy