- 
                Notifications
    You must be signed in to change notification settings 
- Fork 9
🎉 @ast-grep/all-langs #74
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Changes from 10 commits
6fb78ec
              1123d49
              22f74b2
              bd44fae
              8fee8bf
              804d573
              9bdf5b7
              96c72dc
              c298021
              8d96346
              16a40de
              f0dd9ca
              File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,5 @@ | ||
| --- | ||
| "@ast-grep/all-langs": patch | ||
| --- | ||
|  | ||
| New package: @ast-grep/all-langs | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,3 @@ | ||
| { | ||
| "recommendations": ["biomejs.biome"] | ||
| } | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,6 @@ | ||
| { | ||
| "[javascript][json][jsonc][typescript]": { | ||
| "editor.defaultFormatter": "biomejs.biome", | ||
| "editor.minimap.maxColumn": 80 | ||
| } | ||
| } | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1 @@ | ||
| !src | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,72 @@ | ||
| { | ||
| "name": "@ast-grep/all-langs", | ||
| "version": "0.0.0", | ||
| "description": "Exports all officially supported languages.", | ||
| "keywords": ["ast-grep"], | ||
| "homepage": "https://github.com/ast-grep/langs/tree/main/packages/all", | ||
| "bugs": { | ||
| "url": "https://github.com/ast-grep/langs/issues" | ||
| }, | ||
| "license": "ISC", | ||
| "author": { | ||
| "name": "CodeRabbit", | ||
| "url": "https://www.coderabbit.ai" | ||
| }, | ||
| "files": ["dist", "!dist/**/*.test.*"], | ||
| "main": "dist/index.js", | ||
| "repository": "github:ast-grep/langs", | ||
| "scripts": { | ||
| "build": "tsc", | ||
| "clean": "rm -rf dist docs node_modules tsconfig.tsbuildinfo", | ||
| "format": "biome format --write", | ||
| "format:ci": "biome format", | ||
| "lint": "biome lint --fix", | ||
| "lint:ci": "biome lint", | ||
| "pretest": "tsc", | ||
| "test": "node --test './dist/**/*.test.js'" | ||
| }, | ||
| "dependencies": { | ||
| "@ast-grep/lang-angular": "workspace:*", | ||
| "@ast-grep/lang-bash": "workspace:*", | ||
| "@ast-grep/lang-c": "workspace:*", | ||
| "@ast-grep/lang-cpp": "workspace:*", | ||
| "@ast-grep/lang-csharp": "workspace:*", | ||
| "@ast-grep/lang-css": "workspace:*", | ||
| "@ast-grep/lang-dart": "workspace:*", | ||
| "@ast-grep/lang-elixir": "workspace:*", | ||
| "@ast-grep/lang-go": "workspace:*", | ||
| "@ast-grep/lang-haskell": "workspace:*", | ||
| "@ast-grep/lang-html": "workspace:*", | ||
| "@ast-grep/lang-java": "workspace:*", | ||
| "@ast-grep/lang-javascript": "workspace:*", | ||
| "@ast-grep/lang-json": "workspace:*", | ||
| "@ast-grep/lang-kotlin": "workspace:*", | ||
| "@ast-grep/lang-lua": "workspace:*", | ||
| "@ast-grep/lang-php": "workspace:*", | ||
| "@ast-grep/lang-python": "workspace:*", | ||
| "@ast-grep/lang-ruby": "workspace:*", | ||
| "@ast-grep/lang-rust": "workspace:*", | ||
| "@ast-grep/lang-scala": "workspace:*", | ||
| "@ast-grep/lang-sql": "workspace:*", | ||
| "@ast-grep/lang-swift": "workspace:*", | ||
| "@ast-grep/lang-toml": "workspace:*", | ||
| "@ast-grep/lang-tsx": "workspace:*", | ||
| "@ast-grep/lang-typescript": "workspace:*", | ||
| "@ast-grep/lang-yaml": "workspace:*", | ||
| "@ast-grep/napi": "^0.37.0" | ||
| }, | ||
| "devDependencies": { | ||
| "@biomejs/biome": "1.9.4", | ||
|         
                  NatoBoram marked this conversation as resolved.
              Outdated
          
            Show resolved
            Hide resolved | ||
| "@types/node": "22.14.1", | ||
| "typescript": "^5.8.3" | ||
| }, | ||
| "type": "module", | ||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I need to think if we want to ship ESM by default. I prefer to do that but other modules are currently in CJS There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Oh they are? I didn't notice! | ||
| "exports": { | ||
| ".": { | ||
| "types": "./dist/index.d.ts", | ||
| "default": "./dist/index.js" | ||
| } | ||
| }, | ||
| "types": "dist/index.d.ts", | ||
| "module": "dist/index.js" | ||
| } | ||
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,2 @@ | ||
| export * from "./lang.ts" | ||
| export * from "./langs.ts" | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,41 @@ | ||
| import { Lang as LangNapi } from "@ast-grep/napi" | ||
| import test, { describe } from "node:test" | ||
| import { Lang } from "./lang.ts" | ||
|  | ||
| /** Languages supported in `@ast-grep/[email protected]`. */ | ||
| const previous = Object.freeze({ | ||
| Html: "Html", | ||
| JavaScript: "JavaScript", | ||
| Tsx: "Tsx", | ||
| Css: "Css", | ||
| TypeScript: "TypeScript", | ||
| Bash: "Bash", | ||
| C: "C", | ||
| Cpp: "Cpp", | ||
| CSharp: "CSharp", | ||
| Go: "Go", | ||
| Elixir: "Elixir", | ||
| Haskell: "Haskell", | ||
| Java: "Java", | ||
| Json: "Json", | ||
| Kotlin: "Kotlin", | ||
| Lua: "Lua", | ||
| Php: "Php", | ||
| Python: "Python", | ||
| Ruby: "Ruby", | ||
| Rust: "Rust", | ||
| Scala: "Scala", | ||
| Sql: "Sql", | ||
| Swift: "Swift", | ||
| Yaml: 'Yaml', | ||
| }) | ||
|  | ||
| describe("Lang", () => { | ||
| test("The new enum is compatible with the old one", ({ assert }) => { | ||
| for (const lang of Object.values(previous)) assert.equal(Lang[lang], lang) | ||
| }) | ||
|  | ||
| test("The new enum is compatible with the built-in ones", ({ assert }) => { | ||
| for (const lang of Object.values(LangNapi)) assert.equal(Lang[lang], lang) | ||
| }) | ||
| }) | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,37 @@ | ||
| /** | ||
| * An enum of all languages supported by `@ast-grep/langs`. | ||
| */ | ||
| export const Lang = { | ||
| Angular: "Angular", | ||
| Bash: "Bash", | ||
| C: "C", | ||
| Cpp: "Cpp", | ||
| CSharp: "CSharp", | ||
| Css: "Css", | ||
| Dart: "Dart", | ||
| Elixir: "Elixir", | ||
| Go: "Go", | ||
| Haskell: "Haskell", | ||
| Html: "Html", | ||
| Java: "Java", | ||
| JavaScript: "JavaScript", | ||
| Json: "Json", | ||
| Kotlin: "Kotlin", | ||
| Lua: "Lua", | ||
| Php: "Php", | ||
| Python: "Python", | ||
| Ruby: "Ruby", | ||
| Rust: "Rust", | ||
| Scala: "Scala", | ||
| Sql: "Sql", | ||
| Swift: "Swift", | ||
| Toml: "Toml", | ||
| Tsx: "Tsx", | ||
| TypeScript: "TypeScript", | ||
| Yaml: "Yaml", | ||
| } as const | ||
|  | ||
| /** | ||
| * An enum of all languages supported by `@ast-grep/langs`. | ||
| */ | ||
| export type Lang = (typeof Lang)[keyof typeof Lang] | 
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,31 @@ | ||
| import { parse, registerDynamicLanguage } from "@ast-grep/napi" | ||
| import { before, describe, test } from "node:test" | ||
| import { Lang } from "./lang.js" | ||
| import { langs } from "./langs.ts" | ||
|         
                  NatoBoram marked this conversation as resolved.
              Outdated
          
            Show resolved
            Hide resolved | ||
|  | ||
| describe("langs", () => { | ||
| // @ts-expect-error Type `StaticLangRegistration` is missing the following | ||
| // properties from type `LangRegistration`: `libraryPath`, `extensions`. | ||
| before(() => registerDynamicLanguage(langs)) | ||
| 
      Comment on lines
    
      +6
     to 
      +9
    
   There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 💡 Verification agent 🧩 Analysis chainConsider fixing type definitions instead of suppressing errors. Using  🏁 Script executed: #!/bin/bash
# Looking for the definition of StaticLangRegistration and LangRegistration
rg -A 5 "StaticLangRegistration|LangRegistration" --type tsLength of output: 2974 Enhance static‐language type definitions File: packages/all/src/langs.test.ts The TS error here is because your  
 This will remove the need to disable type‐checking and improve long-term maintainability. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think this is a valid concern. if we need error suppression here, does it also mean users need it as well? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 🧩 Analysis chainI need to better understand the type incompatibility between  @HerringtonDarkholme This is an excellent point. If we need to suppress type errors in our own tests, users will likely encounter the same issues when trying to use the package as documented. Let me check how the types are defined to provide a proper solution. 🏁 Script executed: Length of output: 3245 @HerringtonDarkholme You've raised an excellent concern. If our tests need to suppress type errors with  Let me examine the exact types to understand what's happening and suggest a proper solution. 🏁 Script executed: Length of output: 4619 @HerringtonDarkholme I'm trying to find the exact definition of  🏁 Script executed: Length of output: 300 @HerringtonDarkholme You're absolutely right - this issue would affect users too. If we need to use  Looking at the code, we can see: 
 I propose three potential solutions: 
 Option #1 is simplest and would hide the typing issue from users entirely. This would be my recommendation since it provides the best developer experience. 🏁 Script executed: Length of output: 24088 @HerringtonDarkholme You've identified an important issue. Yes, the error suppression would be necessary for users too, which creates a poor developer experience. I've examined the code in detail, and here's what's happening: 
 Proposed solutions:
 I recommend option #1 as it's the simplest and provides the best developer experience. 🧬 Code Graph Analysis ResultsRelevant snippets for understanding  | ||
|  | ||
| // A newly supported language | ||
| test(Lang.Dart, ({ assert }) => { | ||
| const sg = parse(Lang.Dart, 'var x = "Hello, world!";"') | ||
| const kind = sg.root().kind() | ||
| assert.equal(kind, "program") | ||
| }) | ||
|  | ||
| // A previously supported language | ||
| test(Lang.Go, ({ assert }) => { | ||
| const sg = parse(Lang.Go, 'x := "Hello, world!"') | ||
| const kind = sg.root().kind() | ||
| assert.equal(kind, "source_file") | ||
| }) | ||
|  | ||
| // A built-in language | ||
| test(Lang.TypeScript, ({ assert }) => { | ||
| const sg = parse(Lang.TypeScript, 'const x = "Hello, world!"') | ||
| const kind = sg.root().kind() | ||
| assert.equal(kind, "program") | ||
| }) | ||
| }) | ||
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
| @@ -0,0 +1,128 @@ | ||
| import angular from "@ast-grep/lang-angular" | ||
| import bash from "@ast-grep/lang-bash" | ||
| import c from "@ast-grep/lang-c" | ||
| import cpp from "@ast-grep/lang-cpp" | ||
| import csharp from "@ast-grep/lang-csharp" | ||
| import css from "@ast-grep/lang-css" | ||
| import dart from "@ast-grep/lang-dart" | ||
| import elixir from "@ast-grep/lang-elixir" | ||
| import go from "@ast-grep/lang-go" | ||
| import haskell from "@ast-grep/lang-haskell" | ||
| import html from "@ast-grep/lang-html" | ||
| import java from "@ast-grep/lang-java" | ||
| import javascript from "@ast-grep/lang-javascript" | ||
| import json from "@ast-grep/lang-json" | ||
| import kotlin from "@ast-grep/lang-kotlin" | ||
| import lua from "@ast-grep/lang-lua" | ||
| import php from "@ast-grep/lang-php" | ||
| import python from "@ast-grep/lang-python" | ||
| import ruby from "@ast-grep/lang-ruby" | ||
| import rust from "@ast-grep/lang-rust" | ||
| import scala from "@ast-grep/lang-scala" | ||
| import sql from "@ast-grep/lang-sql" | ||
| import swift from "@ast-grep/lang-swift" | ||
| import toml from "@ast-grep/lang-toml" | ||
| import tsx from "@ast-grep/lang-tsx" | ||
| import typescript from "@ast-grep/lang-typescript" | ||
| import yaml from "@ast-grep/lang-yaml" | ||
| import type { | ||
| DynamicLangRegistrations, | ||
| LangRegistration, | ||
| } from "@ast-grep/napi/types/registerDynamicLang.js" | ||
| import { Lang } from "./lang.ts" | ||
|  | ||
| type StaticLangRegistration = | ||
| | typeof angular | ||
| | typeof bash | ||
| | typeof c | ||
| | typeof cpp | ||
| | typeof csharp | ||
| | typeof css | ||
| | typeof dart | ||
| | typeof elixir | ||
| | typeof go | ||
| | typeof haskell | ||
| | typeof html | ||
| | typeof java | ||
| | typeof javascript | ||
| | typeof json | ||
| | typeof kotlin | ||
| | typeof lua | ||
| | typeof php | ||
| | typeof python | ||
| | typeof ruby | ||
| | typeof rust | ||
| | typeof scala | ||
| | typeof sql | ||
| | typeof swift | ||
| | typeof toml | ||
| | typeof tsx | ||
| | typeof typescript | ||
| | typeof yaml | ||
| | LangRegistration | ||
|  | ||
| interface StaticLangRegistrations { | ||
| Angular: typeof angular | ||
| Bash: typeof bash | ||
| C: typeof c | ||
| Cpp: typeof cpp | ||
| CSharp: typeof csharp | ||
| Css: typeof css | ||
| Dart: typeof dart | ||
| Elixir: typeof elixir | ||
| Go: typeof go | ||
| Haskell: typeof haskell | ||
| Html: typeof html | ||
| Java: typeof java | ||
| JavaScript: typeof javascript | ||
| Json: typeof json | ||
| Kotlin: typeof kotlin | ||
| Lua: typeof lua | ||
| Php: typeof php | ||
| Python: typeof python | ||
| Ruby: typeof ruby | ||
| Rust: typeof rust | ||
| Scala: typeof scala | ||
| Sql: typeof sql | ||
| Swift: typeof swift | ||
| Toml: typeof toml | ||
| Tsx: typeof tsx | ||
| TypeScript: typeof typescript | ||
| Yaml: typeof yaml | ||
|  | ||
| /** To satisfy {@link DynamicLangRegistrations}. */ | ||
| [langName: string]: StaticLangRegistration | ||
| } | ||
|  | ||
| /** | ||
| * Built-in dynamic languages supported by `@ast-grep/langs`. | ||
| */ | ||
| export const langs: StaticLangRegistrations = { | ||
| [Lang.Angular]: angular, | ||
| [Lang.Bash]: bash, | ||
| [Lang.C]: c, | ||
| [Lang.Cpp]: cpp, | ||
| [Lang.CSharp]: csharp, | ||
| [Lang.Css]: css, | ||
| [Lang.Dart]: dart, | ||
| [Lang.Elixir]: elixir, | ||
| [Lang.Go]: go, | ||
| [Lang.Haskell]: haskell, | ||
| [Lang.Html]: html, | ||
| [Lang.Java]: java, | ||
| [Lang.JavaScript]: javascript, | ||
| [Lang.Json]: json, | ||
| [Lang.Kotlin]: kotlin, | ||
| [Lang.Lua]: lua, | ||
| [Lang.Php]: php, | ||
| [Lang.Python]: python, | ||
| [Lang.Ruby]: ruby, | ||
| [Lang.Rust]: rust, | ||
| [Lang.Scala]: scala, | ||
| [Lang.Sql]: sql, | ||
| [Lang.Swift]: swift, | ||
| [Lang.Toml]: toml, | ||
| [Lang.Tsx]: tsx, | ||
| [Lang.TypeScript]: typescript, | ||
| [Lang.Yaml]: yaml, | ||
| } | 
Uh oh!
There was an error while loading. Please reload this page.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
💡 Verification agent
🧩 Analysis chain
Validate Node.js version range in CI
Please confirm that the
actions/setup-nodeaction supports the semver range">= 21". Also ensure that the release workflow (.github/workflows/release.yml) has been updated in the same way for consistency.🏁 Script executed:
Length of output: 924
🌐 Web query:
💡 Result:
Support for Semver Ranges in
actions/setup-nodeYes, the GitHub Actions
actions/setup-nodeaction supports Semantic Versioning (semver) ranges for thenode-versioninput.Details
The
node-versioninput accepts semver range notations, allowing you to specify versions like'14.x','16','>=16.0.0', and similar patterns. For example:'16.x'will use the latest available patch version of Node.js 16.'>=18.0.0'will resolve to the latest version matching the range[2][4][6].This is explicitly supported in the official documentation and examples:
You can also use other accepted notations such as:
'lts/*'for the latest LTS version'latest'for the most recent Node.js release'16.13.0'The
setup-nodeaction internally uses semver resolution logic to pick the appropriate Node.js version based on the provided range, and this is compatible with the NPM ecosystem’snode-semverparser[3][4].Example Usage
or
Version Files and Ranges
.nvmrc,.node-version,package.json). If a semver range is provided in these files (e.g., viaengines.nodeinpackage.json), that will be used as the version specification[1][6].Summary Table
'16.x''>=18.0.0''lts/*''latest''14','14.x'In conclusion, use semver ranges or aliases as the
node-versioninput for flexibility in your GitHub Actions workflows[2][4][5][6].Citations:
🌐 Web query:
💡 Result:
Input Parameters for
actions/setup-node@v4actions/setup-node@v4 provides a range of input parameters to configure Node.js environments in GitHub Actions workflows. Below are the primary and advanced inputs you can use, with notes on precedence and intended use:
Core Version Selection Inputs
node-version
Specifies the Node.js version to use (accepts SemVer, aliases like
lts/*,latest,nightly, or canary builds).Example:
If both
node-versionandnode-version-fileare provided,node-versiontakes precedence[1][2][6][9].node-version-file
Path to a file containing the Node.js version (e.g.,
.nvmrc,.node-version,.tool-versions, orpackage.json).Example:
Notable behavior: In a
package.json, it checksvolta.nodefirst, thenengines.nodeifvolta.nodeis unspecified[1][6].Update and Architecture Controls
check-latest
Boolean (
trueorfalse). Iftrue, downloads the latest available version matching the specification, bypassing local cache. Defaults tofalse, which favors cached versions for performance[1][6][9].Example:
architecture
Target CPU architecture for Node.js (e.g.,
x86,x64,arm64). Defaults to the system architecture if unspecified[2][6][9].Example:
Caching and Authentication (Advanced)
cache
Specifies dependency manager to cache (
npm,yarn,pnpm, or''to disable)[2][6].cache-dependency-path
Sets the path to lock file(s) for cache key calculation (used if lock file is not in root).
registry-url and scope
Used to set up npm registry authentication, particularly with private registries.
token
Custom token for publishing/authenticating with npm/GitHub package registries.
Summary Table
'18','lts/*','16.13.0'node-version-file.'.nvmrc','package.json'true,falsefalse.'x64','arm64''npm','yarn','pnpm''frontend/yarn.lock''https://npm.pkg.github.com''@my-org''${{ secrets.NPM_TOKEN }}'No
versionInputnode-version(not justversion). There is noversioninput; always usenode-versionwhen specifying the desired Node.js release[2][9].Example Usage
References
In summary:
Use
node-versionto specify the Node.js version (notversion).node-version-filecan be used to read the version from a file, but is overridden by a directnode-versioninput. Additional parameters provide update, architecture, caching, and authentication controls for your workflow[1][2][6][9].Citations:
Update release workflow to use
node-versioninputThe
actions/setup-node@v4action does support SemVer ranges (e.g.">= 21") via thenode-versioninput. Your CI workflow already uses:However, in your release workflow you’re still using the wrong parameter (
version: 9) in two places. Please update both steps in.github/workflows/release.ymlto:– once at line 39 (and its corresponding cache block) and again at line 73.
Ensure you’re using
node-version(notversion) for consistency with the CI workflow and the action’s documentation.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
do we need this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🧩 Analysis chain
🏁 Script executed:
Length of output: 2101
🏁 Script executed:
Length of output: 1218
🏁 Script executed:
Length of output: 910
@HerringtonDarkholme Based on what I found, this change does appear to be useful for consistency:
node-version: ">= 21"specified@types/nodeversion 22.14.1 (which corresponds to Node.js 22 APIs)node:test) and ES module featuresWhile there's no explicit
enginesfield in package.json defining Node.js requirements, maintaining the same Node.js version constraint across both CI and release workflows ensures consistency in your build environments.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Haha, @coderabbitai getting confused at
pnpm/action-setup@v4vsactions/setup-node@v4. Theversion: 9parameter is for setting uppnpm(not Node), but it's saying to usenode-versionthere, which is wrong.The code it highlighted as wrong, this one;
simply does not exist. This is the real code:
which is correct
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@NatoBoram You're absolutely right, and I apologize for the confusion! I completely mixed up the two different actions:
pnpm/action-setup@v4- correctly usesversion: 9for pnpm versionactions/setup-node@v4- correctly usesnode-version: ">= 21"for Node.js versionYour code is indeed correct as shown. Thanks for the clarification and for pointing out this mistake. I'll make sure to be more careful distinguishing between different actions and their parameters in the future.
(_/)
(•ㅅ•)
/ づ ♡