commonMain.io.exoquery.pprint.Walker.kt Maven / Gradle / Ivy
package io.exoquery.pprint
import io.exoquery.fansi.Attrs
//import java.util.*
//import kotlin.collections.LinkedHashMap
//import kotlin.reflect.full.allSuperclasses
/**
* A lazy AST representing pretty-printable text. Models `foo(a, b)`
* `foo op bar`, and terminals `foo` in both lazy and eager forms
*/
sealed interface Tree {
/**
* Foo(aa, bbb, cccc)
*/
data class Apply(val prefix: String, val body: Iterator): Tree
/**
* LHS op RHS
*/
data class Infix(val lhs: Tree, val op: String, val rhs: Tree): Tree
/**
* "xyz"
*/
data class Literal(val body: String): Tree{
val hasNewLine = body.any { c -> c == '\n' || c == '\r' }
}
/**
* x = y
*/
data class KeyValue(val key: String, val value: Tree): Tree
/**
* xyz
*/
data class Lazy(val body0: (Ctx) -> Iterator): Tree
data class Ctx(
val width: Int,
val leftOffset: Int,
val indentCount: Int,
val indentStep: Int,
val literalColor: Attrs,
val applyPrefixColor: Attrs
)
}
abstract class EncodeHelper {
abstract fun makeHexString(c: Char): String
fun encodeChar(x: Char, escapeUnicode: Boolean): Tree.Literal {
val sb = StringBuilder()
sb.append('\'')
Util.escapeChar(x, sb, escapeUnicode, ::makeHexString)
sb.append('\'')
return Tree.Literal(sb.toString())
}
fun encodeString(x: String, escapeUnicode: Boolean): Tree.Literal {
return if (x.any {c -> c == '\n' || c == '\r'}) Tree.Literal("\"\"\"" + x + "\"\"\"")
else Tree.Literal(Util.literalize(x.toCharArray(), escapeUnicode, ::makeHexString))
}
}
interface Walker {
val showGenericForCollections: Boolean
// No additional handlers. To extend, override the treeify function
// fun additionalHandlers: PartialFunction
fun treeify(x: T, escapeUnicode: Boolean, showFieldNames: Boolean): Tree
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy