class Analyzer::Java::Spark

Overview

Spark Java is Sinatra-flavoured: Spark.get("/x", (req, res) -> ...) (or just get("/x", ...) after import static spark.Spark.*). Path nesting is path("/api", () -> { ... }). The shared lambda-DSL extractor handles all of that; this analyzer just supplies the Spark method-name set.

Defined in:

analyzer/analyzers/java/spark.cr

Constant Summary

CONFIG = Noir::TreeSitterJvmLambdaDslExtractor::Config.new(verb_methods: {"get" => "GET", "post" => "POST", "put" => "PUT", "delete" => "DELETE", "patch" => "PATCH", "head" => "HEAD", "options" => "OPTIONS", "trace" => "TRACE", "connect" => "CONNECT", "any" => "ANY"}, nest_methods: Set {"path"}, transparent_methods: Set {"before", "after", "afterAfter"}, query_methods: Set {"queryParams", "queryParamOrDefault", "queryParamsValues"}, header_methods: Set {"headers"}, cookie_methods: Set {"cookie"}, body_methods: Set {"body", "bodyAsBytes"}, websocket_methods: Set {"webSocket"})

Spark's request helpers. body() returns the raw body string (no type info) — emit a generic body param. queryParams serves both query string and form data; we surface it as query since Spark callers most commonly read it that way.

JAVA_EXTENSION = "java"
SPARK_MARKERS = ["spark.Spark", "import static spark.", "import spark."]

Instance Method Summary

Instance methods inherited from class Analyzer

analyze analyze, base_path : String base_path, base_paths : Array(String) base_paths, callees_needed? : Bool callees_needed?, logger : NoirLogger logger, parallel_analyze(channel : Channel(String), &block : String -> Nil) parallel_analyze, read_file_content(path : String) : String read_file_content, result : Array(Endpoint) result, url : String url

Constructor methods inherited from class Analyzer

new(options : Hash(String, YAML::Any)) new

Macros inherited from class Analyzer

define_getter_methods(names) define_getter_methods

Instance methods inherited from module FileHelper

all_files : Array(String) all_files, get_files_by_extension(extension : String) : Array(String) get_files_by_extension, get_files_by_prefix(prefix : String) : Array(String) get_files_by_prefix, get_files_by_prefix_and_extension(prefix : String, extension : String) : Array(String) get_files_by_prefix_and_extension, get_public_dir_files(base_path : String, folder : String) : Array(String) get_public_dir_files, get_public_files(base_path : String, anchors : Array(String) = ["shard.yml", "Gemfile"]) : Array(String) get_public_files, populate_channel_with_files(channel : Channel(String)) populate_channel_with_files, populate_channel_with_filtered_files(channel : Channel(String), extension : String)
populate_channel_with_filtered_files(channel : Channel(String), extensions : Array(String))
populate_channel_with_filtered_files

Instance Method Detail

def analyze #

[View source]