Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
rescript-atdgen-generator
Advanced tools
Atdgen prebuilt binaries for 3 major OS platforms.
This is capped at version 2.15.0, after which BuckleScript support (which ReScript relies on) was removed. https://github.com/ahrefs/atd/pull/375
If atd
proves to be a popular tool for ReScript projects it can be restored fairly easily.
(Prefer example? Check the test folder)
This tool will not work without a library that implements the ATD BuckleScript runtime API. A ReScript implementation is in progress, in the meantime bs-atdgen-codec-runtime
still works - but not on ReScript 11.
With yarn or npm:
yarn add -D rescript-atdgen-generator
npm i -D rescript-atdgen-generator
We then need to define atd
as a generator in rescript.json
. For compatibility with windows development, the recommended approach is a direct reference to atdgen.exe
. Generators are run in the lib/bs
folder context, so a leading ../..
is required:
"generators": [
{
"name": "atd_types",
"command": "../../node_modules/.bin/atdgen -t $in"
},
{
"name": "atd_runtime",
"command": "../../node_modules/.bin/atdgen -bs $in"
}
],
If windows compatibility is not required, or for more complex monorepo scenarios, these commands can be replaced by the shorter npx atdgen -t $in
and npx atdgen -bs $in
(or using yarn run
instead of npx
). This approach is however a little slower due to the extra nodejs invocations.
Now that the generator is defined, add the files that need to be processed to sources
. ReScript requires a manual definition for every file that the generator will process. For atd
, this means a pair of entries must be defined for every .atd
file in your project. Both "types" and "runtime" representations are required, and each generates both an interface and a code file.
"sources": {
// given a `my-generated-source` folder, define generators for the file `meetup.atd` in that folder.
// it is not necessary to have a dedicated folder for generated sources,
// but it does help avoid generated files getting in the way.
{
"dir": "my-generated-source",
"generators": [
{
"name": "atd_types",
"edge": ["meetup_t.ml", "meetup_t.mli", ":", "meetup.atd"]
},
{
"name": "atd_runtime",
"edge": ["meetup_bs.ml", "meetup_bs.mli", ":", "meetup.atd"]
}
]
},
// ...other source folders
"src1",
"src2"
},
The syntax here is a little weird, the edge
array defines a build syntax recognised by the compiler. The order of this array is very important; it must be the two files that atd
generates, a :
, and then the source file that serves as the input to the generator command.
Updates to the source file are what the compiler uses to determine whether the generator needs to run. The generated files can freely be ignored by source control.
All code is licensed as MIT. See LICENSE.
This project was transferred to me by Javier Chávarri after it was abandoned following the switch of ahrefs to Melange.
FAQs
Atdgen prebuilt binaries for 3 major OS platforms.
We found that rescript-atdgen-generator demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.