2018-08-24 18:42:07 +02:00
|
|
|
/**
|
|
|
|
* Splash
|
|
|
|
* Copyright (c) John Sundell 2018
|
|
|
|
* MIT license - see LICENSE.md
|
|
|
|
*/
|
|
|
|
|
|
|
|
import Foundation
|
|
|
|
|
|
|
|
/// A representation of a segment of code, used to determine the type
|
|
|
|
/// of a given token when passed to a `SyntaxRule` implementation.
|
|
|
|
public struct Segment {
|
|
|
|
/// The code that prefixes this segment, that is all the characters
|
|
|
|
/// up to where the segment's current token begins.
|
|
|
|
public var prefix: Substring
|
|
|
|
/// The collection of tokens that the segment includes
|
|
|
|
public var tokens: Tokens
|
|
|
|
/// Any whitespace that immediately follows the segment's current token
|
|
|
|
public var trailingWhitespace: String?
|
|
|
|
|
|
|
|
internal let currentTokenIsDelimiter: Bool
|
|
|
|
internal var isLastOnLine: Bool
|
|
|
|
}
|
|
|
|
|
|
|
|
public extension Segment {
|
|
|
|
/// A collection of tokens included in a code segment
|
|
|
|
struct Tokens {
|
2018-08-27 00:10:08 +02:00
|
|
|
/// All tokens that have been found so far (excluding the current one)
|
|
|
|
public var all: [String]
|
2018-08-24 18:42:07 +02:00
|
|
|
/// The number of times a given token has been found up until this point
|
2018-08-27 00:10:08 +02:00
|
|
|
public var counts: [String : Int]
|
2018-08-24 18:42:07 +02:00
|
|
|
/// The tokens that were previously found on the same line as the current one
|
2018-08-27 00:10:08 +02:00
|
|
|
public var onSameLine: [String]
|
2018-08-24 18:42:07 +02:00
|
|
|
/// The token that was previously found (may be on a different line)
|
2018-08-27 00:10:08 +02:00
|
|
|
public var previous: String?
|
2018-08-24 18:42:07 +02:00
|
|
|
/// The current token which is currently being evaluated
|
2018-08-27 00:10:08 +02:00
|
|
|
public var current: String
|
2018-08-24 18:42:07 +02:00
|
|
|
/// Any upcoming token that will follow the current one
|
2018-08-27 00:10:08 +02:00
|
|
|
public var next: String?
|
2018-08-24 18:42:07 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public extension Segment.Tokens {
|
|
|
|
/// Return the number of times a given token has been found up until this point.
|
|
|
|
/// This is a convenience API over the `counts` dictionary.
|
|
|
|
func count(of token: String) -> Int {
|
|
|
|
return counts[token] ?? 0
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Return whether an equal number of occurrences have been found of two tokens.
|
|
|
|
/// For example, this can be used to check if a token is encapsulated by parenthesis.
|
|
|
|
func containsBalancedOccurrences(of tokenA: String, and tokenB: String) -> Bool {
|
|
|
|
return count(of: tokenA) == count(of: tokenB)
|
|
|
|
}
|
|
|
|
}
|