class
Analyzer::Javascript::Fresh
Overview
Fresh is Deno's filesystem-routed framework. Routes live under
routes/ and the URL is derived from the directory layout:
routes/index.tsx → GET / routes/about.tsx → GET /about routes/users/index.tsx → GET /users routes/users/[id].tsx → GET /users/{id} routes/api/users.ts → handler-driven verbs routes/[...slug].tsx → GET /{slug}
Verb shape:
-
Page files (
.tsx/.jsx) with aexport defaultcomponent render HTML — emit GET. -
Resource files export a
handlerobject whose keys are HTTP verbs:export const handler: Handlers = { GET(req, ctx) { ... }, async POST(req, ctx) { ... }, PUT: async (req) => { ... }, };Each verb-shaped key (method shorthand or property assignment) registers a route.
-
If
handleris a single function (no object), Fresh dispatches every method to it — fall back to the standard handler set (GET / POST / PUT / DELETE / PATCH).
Underscore-prefixed files (_app.tsx, _layout.tsx,
_404.tsx, _500.tsx, _middleware.ts) are framework
plumbing — not user-facing routes — and skipped.
Out of scope for this first cut:
- Per-handler request-helper scanning. Fresh handlers receive
(req, ctx)— accurate read tracking needs cross-call value flow. Path placeholders still surface via the optimizer. - Route groups (
(group)directories — same convention as SvelteKit). Add when fixtures show real-world usage.
Defined in:
analyzer/analyzers/javascript/fresh.crConstant Summary
-
API_EXTENSIONS =
[".ts", ".js", ".mjs"] -
EXTENSIONS =
PAGE_EXTENSIONS + API_EXTENSIONS -
FALLBACK_HANDLER_METHODS =
["GET", "POST", "PUT", "DELETE", "PATCH"] -
HTTP_METHODS =
["GET", "POST", "PUT", "DELETE", "PATCH", "HEAD", "OPTIONS"] -
PAGE_EXTENSIONS =
[".tsx", ".jsx"] -
SKIPPED_LEAVES =
["_app", "_layout", "_404", "_500", "_middleware"] -
Files that are framework plumbing rather than routes.
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