aboutsummaryrefslogtreecommitdiff
path: root/src/Lexical.kt
diff options
context:
space:
mode:
authorMarvin Borner2019-08-14 22:31:46 +0200
committerMarvin Borner2019-08-14 22:31:46 +0200
commit938f655b120efd01a0fbdd5c3fde7dbc1b53d267 (patch)
treed7e7ff88280a110e1220573ff41e79cc98baa68b /src/Lexical.kt
parent38aad3dcda01fc5ed82556dbfdf4cfc30ff479d9 (diff)
Using Kotlin/Native now
Diffstat (limited to 'src/Lexical.kt')
-rw-r--r--src/Lexical.kt68
1 files changed, 0 insertions, 68 deletions
diff --git a/src/Lexical.kt b/src/Lexical.kt
deleted file mode 100644
index df60a8e..0000000
--- a/src/Lexical.kt
+++ /dev/null
@@ -1,68 +0,0 @@
-import exceptions.UnknownType
-
-class Lexical {
- fun analyze(source: String): MutableList<Pair<String, TokenType>> {
- var buffer = ""
- var stringMode = false
- val tokens = mutableListOf<Pair<String, TokenType>>()
- for (i in source.indices) {
- buffer += source[i]
- val tokenType = getTokenType(buffer, if (source.length > i + 1) source[i + 1] else ' ', stringMode)
- if (tokenType != TokenType.Skip) {
- tokens += buffer to tokenType
- if (buffer == "\"") stringMode = true
- buffer = ""
- }
- if (tokenType == TokenType.Empty) buffer = ""
- }
- return tokens
- }
-
- /**
- * Matches the tokens to a [TokenType]
- */
- private fun getTokenType(token: String, next: Char, stringMode: Boolean): TokenType {
- return when {
- token + next in keyword -> TokenType.Skip
- token in keyword -> TokenType.Keyword
-
- token + next in comparison -> TokenType.Skip
- token in assignment -> TokenType.Assignment
-
- token + next in assignment -> TokenType.Skip
- token in arithmetic -> TokenType.Arithmetic
-
- token + next in comparison -> TokenType.Skip
- token in comparison -> TokenType.Comparison
-
- token + next in comparison -> TokenType.Skip
- token in logical -> TokenType.Logical
-
- (token + next).matches(Regex("[a-zA-Z]*")) -> TokenType.Skip
- token.matches(Regex("[a-zA-Z]*")) -> TokenType.Identifier
-
- (token + next).matches(Regex("[0-9]*")) -> TokenType.Skip
- token.matches(Regex("[0-9]*")) -> TokenType.Constant
-
- token in punctuation -> TokenType.Punctuation
-
- token in brackets -> TokenType.Bracket
-
- token in classifier -> TokenType.Classifier
-
- token.contains(" ") && token.length > 1 && !stringMode -> throw UnknownType(token)
- token == " " && !stringMode -> TokenType.Empty
-
- else -> TokenType.Skip
- }
- }
-
- private val keyword = listOf("print") // TODO: DataType matching
- private val assignment = listOf("=", "+=", "-=", "*=", "/*")
- private val arithmetic = listOf("+", "-", "*", "/", "%")
- private val comparison = listOf("==", "!=", "<", "<=", ">", ">=")
- private val logical = listOf("&&", "||", "!")
- private val punctuation = listOf(",", ":", ".")
- private val brackets = listOf("(", ")", "[", "]", "{", "}") // TODO: Use brackets for functions
- private val classifier = listOf("\"") // TODO: Add char mode e.g 'a'
-}