Skip to content

Commit

Permalink
Merge branch 'main' into mk/iniForConsoleNeo4j
Browse files Browse the repository at this point in the history
  • Loading branch information
maximiliankaul committed Dec 2, 2024
2 parents 35dffc2 + 05631c5 commit 6e1c18f
Showing 1 changed file with 60 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -26,33 +26,36 @@
package de.fraunhofer.aisec.cpg.frontends.ini

import de.fraunhofer.aisec.cpg.TranslationContext
import de.fraunhofer.aisec.cpg.frontends.Handler
import de.fraunhofer.aisec.cpg.frontends.Language
import de.fraunhofer.aisec.cpg.frontends.LanguageFrontend
import de.fraunhofer.aisec.cpg.frontends.TranslationException
import de.fraunhofer.aisec.cpg.graph.*
import de.fraunhofer.aisec.cpg.graph.declarations.FieldDeclaration
import de.fraunhofer.aisec.cpg.graph.declarations.NamespaceDeclaration
import de.fraunhofer.aisec.cpg.graph.declarations.RecordDeclaration
import de.fraunhofer.aisec.cpg.graph.declarations.TranslationUnitDeclaration
import de.fraunhofer.aisec.cpg.graph.statements.expressions.Literal
import de.fraunhofer.aisec.cpg.graph.types.Type
import de.fraunhofer.aisec.cpg.sarif.PhysicalLocation
import de.fraunhofer.aisec.cpg.sarif.Region
import java.io.File
import java.io.FileInputStream
import java.net.URI
import org.ini4j.Ini
import org.ini4j.Profile
import org.ini4j.Profile.Section

/**
* The INI file frontend. This frontend utilizes the [ini4j library](https://ini4j.sourceforge.net/)
* to parse the config file. The result consists of
* - a [TranslationUnitDeclaration] wrapping the entire result
* - a [de.fraunhofer.aisec.cpg.graph.declarations.NamespaceDeclaration] wrapping the INI file and
* thus preventing collisions with other symbols which might have the same name
* - a [NamespaceDeclaration] wrapping the INI file and thus preventing collisions with other
* symbols which might have the same name
* - a [RecordDeclaration] per `Section` (a section refers to a block of INI values marked with a
* line `[SectionName]`)
* - a [de.fraunhofer.aisec.cpg.graph.declarations.FieldDeclaration] per entry in a section. The
* [de.fraunhofer.aisec.cpg.graph.declarations.FieldDeclaration.name] matches the `entry`s `name`
* field and the [de.fraunhofer.aisec.cpg.graph.declarations.FieldDeclaration.initializer] is set
* to a [statements.expressions.Literal] with the corresponding `entry`s `value`.
* - a [FieldDeclaration] per entry in a section. The [FieldDeclaration.name] matches the `entry`s
* `name` field and the [FieldDeclaration.initializer] is set to a [Literal] with the
* corresponding `entry`s `value`.
*
* Note:
* - the "ini4j" library does not provide any super type for all nodes. Thus, the frontend accepts
Expand All @@ -63,8 +66,7 @@ import org.ini4j.Profile
* `.toString()`
* - [locationOf] always returns `null` as the "ini4j" library does not provide any means of getting
* a location given a node
* - [setComment] not implemented as this is not used (no
* [de.fraunhofer.aisec.cpg.frontends.Handler] pattern implemented)
* - [setComment] not implemented as this is not used (no [Handler] pattern implemented)
* - Comments in general are not supported.
*/
class IniFileFrontend(language: Language<IniFileFrontend>, ctx: TranslationContext) :
Expand Down Expand Up @@ -116,7 +118,7 @@ class IniFileFrontend(language: Language<IniFileFrontend>, ctx: TranslationConte
* Translates a `Section` into a [RecordDeclaration] and handles all `entries` using
* [handleEntry].
*/
private fun handleSection(section: Profile.Section) {
private fun handleSection(section: Section) {
val record = newRecordDeclaration(name = section.name, kind = "section", rawNode = section)
scopeManager.addDeclaration(record)
scopeManager.enterScope(record)
Expand All @@ -125,10 +127,8 @@ class IniFileFrontend(language: Language<IniFileFrontend>, ctx: TranslationConte
}

/**
* Translates an `MutableEntry` to a new
* [de.fraunhofer.aisec.cpg.graph.declarations.FieldDeclaration] with the
* [de.fraunhofer.aisec.cpg.graph.declarations.FieldDeclaration.initializer] being set to the
* `entry`s value.
* Translates an `MutableEntry` to a new [FieldDeclaration] with the
* [FieldDeclaration.initializer] being set to the `entry`s value.
*/
private fun handleEntry(entry: MutableMap.MutableEntry<String?, String?>) {
val field =
Expand All @@ -141,8 +141,53 @@ class IniFileFrontend(language: Language<IniFileFrontend>, ctx: TranslationConte
return primitiveType("string")
}

/**
* Returns an approximation of the original code by re-creating (parts of) the INI file given
* the parsed results provided by ini4j. This is not a perfect representation of the original
* code (comments, order, ...), however re-parsing it should result in the same
* CPG-representation.
*/
override fun codeOf(astNode: Any): String? {
return astNode.toString()
return when (astNode) {
is Ini -> codeOfIni(astNode)
is Section -> codeOfSection(astNode)
is Map.Entry<*, *> -> codeOfEntry(astNode)
else -> null
}
}

/**
* Returns an approximation of the original code by re-creating (parts of) the INI file given
* the parsed results provided by ini4j. This is not a perfect representation of the original
* code (comments, order, ...), however re-parsing it should result in the same
* CPG-representation.
*/
private fun codeOfIni(ini: Ini): String {
return ini.values.joinToString(System.lineSeparator()) { codeOfSection(it) }
}

/**
* Returns an approximation of the original code by re-creating (parts of) the INI file given
* the parsed results provided by ini4j. This is not a perfect representation of the original
* code (comments, order, ...), however re-parsing it should result in the same
* CPG-representation.
*/
private fun codeOfEntry(entry: Map.Entry<*, *>): String {
return "${entry.key} = ${entry.value}"
}

/**
* Returns an approximation of the original code by re-creating (parts of) the INI file given
* the parsed results provided by ini4j. This is not a perfect representation of the original
* code (comments, order, ...), however re-parsing it should result in the same
* CPG-representation.
*/
private fun codeOfSection(section: Section): String {
return "[" +
section.name +
"]" +
System.lineSeparator() +
section.entries.joinToString(System.lineSeparator()) { codeOfEntry(it) }
}

/**
Expand Down

0 comments on commit 6e1c18f

Please sign in to comment.