class
Analyzer::Scala::Tapir
- Analyzer::Scala::Tapir
- Analyzer::Scala::ScalaEngine
- Analyzer
- Reference
- Object
Defined in:
analyzer/analyzers/scala/tapir.crConstant Summary
-
BASE_ENDPOINT_RE =
/(?<![.\w])(?:[A-Za-z_]\w*[Ee]ndpoint|endpoint|infallibleEndpoint)\b/ -
HTTP_METHODS =
["get", "post", "put", "delete", "patch", "head", "options", "connect", "trace"] of ::String -
IN_TOKEN_RE =
Regex.new("\"(?<literal>[^\"]+)\"|path\\[(?<path_type>#{TYPE_PATTERN})\\](?:\\s*\\(\\s*\"(?<path_name>[^\"]+)\"\\s*\\))?|query\\[(?<query_type>#{TYPE_PATTERN})\\]\\s*\\(\\s*\"(?<query_name>[^\"]+)\"\\s*\\)|queries\\[(?<queries_type>#{TYPE_PATTERN})\\]\\s*\\(\\s*\"(?<queries_name>[^\"]+)\"\\s*\\)|header\\[(?<header_type>#{TYPE_PATTERN})\\]\\s*\\(\\s*\"(?<header_name>[^\"]+)\"\\s*\\)|header\\s*\\(\\s*\"(?<header_name2>[^\"]+)\"|cookie\\[(?<cookie_type>#{TYPE_PATTERN})\\]\\s*\\(\\s*\"(?<cookie_name>[^\"]+)\"\\s*\\)|(?<body>jsonBody|xmlBody|stringBody|plainBody|binaryBody|byteArrayBody|byteBufferBody|formBody|multipartBody|rawBinaryBody|fileBody)(?:\\[(?<body_type>#{TYPE_PATTERN})\\])?") -
METHOD_CALL_PATTERNS =
HTTP_METHODS.map do |m| {m, /\.#{m}\b/} end -
Crystal recompiles an interpolated regex literal on every evaluation (a full PCRE2 JIT compile) — precompile the fixed per-verb matchers once at load time instead of per chain.
-
MODIFIERS =
"(?:(?:private|protected|implicit|lazy|final|override)\\s+)*" -
PARAM_CONST_RE =
Regex.new("^\\s*#{MODIFIERS}val\\s+(\\w+)\\s*=\\s*((?:query|queries|header|cookie|path)\\[#{TYPE_PATTERN}\\]\\s*\\(\\s*\"[^\"]+\"\\s*\\)|header\\s*\\(\\s*\"[^\"]+\"\\s*\\))") -
val limitParameter = query[Option[Int]]("limit")...— a reusable input combinator bound to a val. Only the combinator core is captured so any trailing.description(...)is dropped. -
PATH_CONST_RE =
Regex.new("^\\s*#{MODIFIERS}val\\s+(\\w+)\\s*(?::\\s*String\\s*)?=\\s*(\"(?:[^\"\\\\]|\\\\.)*\"(?:\\s*/\\s*\"(?:[^\"\\\\]|\\\\.)*\")*)\\s*$") -
val UserPath = "user"(optionally/-joined literals). The captured value is already in literal form, so substituting it back into a.in(...)block lets the normal path-literal scan pick up the segments. -
TYPE_PATTERN =
"(?:[^\\[\\]]|\\[[^\\[\\]]*\\])+" -
Type token allows one level of nested brackets (e.g. Option[String], List[User]).
-
VAL_DEF_RE =
/^\s*(?:(?:private|protected|implicit|lazy|final|override)\s+)*val\s+(\w+)\s*(?::\s*[^=]+?\s*)?=(?![=>])\s*/ -
Leading
val NAME [: TYPE] =of a definition. Group 1 captures the name;match.endmarks where the right-hand side (the actual endpoint chain) begins.=(?![=>])avoids stopping on==/=>.