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

io.joern.c2cpg.passes.PreprocessorPass.scala Maven / Gradle / Ivy

There is a newer version: 4.0.80
Show newest version
package io.joern.c2cpg.passes

import io.joern.c2cpg.C2Cpg.DefaultIgnoredFolders
import io.joern.c2cpg.Config
import io.joern.c2cpg.parser.{CdtParser, FileDefaults}
import io.joern.x2cpg.SourceFiles
import org.eclipse.cdt.core.dom.ast.{
  IASTPreprocessorIfStatement,
  IASTPreprocessorIfdefStatement,
  IASTPreprocessorStatement
}

import java.nio.file.Paths
import scala.collection.parallel.CollectionConverters.ImmutableIterableIsParallelizable
import scala.collection.parallel.immutable.ParIterable

class PreprocessorPass(config: Config) {

  private val parser = new CdtParser(config)

  def run(): ParIterable[String] =
    SourceFiles
      .determine(
        config.inputPath,
        FileDefaults.SOURCE_FILE_EXTENSIONS,
        ignoredDefaultRegex = Option(DefaultIgnoredFolders),
        ignoredFilesRegex = Option(config.ignoredFilesRegex),
        ignoredFilesPath = Option(config.ignoredFiles)
      )
      .par
      .flatMap(runOnPart)

  private def preprocessorStatement2String(stmt: IASTPreprocessorStatement): Option[String] = stmt match {
    case s: IASTPreprocessorIfStatement =>
      Option(s"${s.getCondition.mkString}${if (s.taken()) "=true" else ""}")
    case s: IASTPreprocessorIfdefStatement =>
      Option(s"${s.getCondition.mkString}${if (s.taken()) "=true" else ""}")
    case _ => None
  }

  private def runOnPart(filename: String): Iterable[String] =
    parser.preprocessorStatements(Paths.get(filename)).flatMap(preprocessorStatement2String).toSet

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy