Skip to content

ULL-ESIT-PL/babel-left-side-npm-test

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

44 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

What is this?

Caution

This is a work in progress. The syntax and the semantic of the proposed extension to JavaScript are not yet fully defined and tested. The packages are published in the GitHub registry, but they are not ready for production.

This is a repo illustrating how to use Pablo Santana's set of packages published in the GitHub registry inside the ull-esit-pl organization. These packages extend the JavaScript language with a new kind of functions. The packages are:

The proposed Syntax and Semantic

These packages extend JS with a new kind of functions, the @@ functions (we lack of a name for this class of functions: assignable? pure?). Here is an example of declaring an assignable function:

function @@ foo(bar) {
  return bar * 2;
}

These assignable functions can be later modified using the assign expression:

foo(10) = 5;

Here is the full code for our "hello" left-side-plugin example:

➜ babel-npm-test git:(main) cat example.js

function @@ foo(bar) {
  return bar * 2;
}
foo(10) = 5;

console.log(foo(10)); //  5
console.log(foo(5));  // 10

You can fork this repo and test the packages in your own workspace.

Install

Here are the node and npm versions I have used to test the packages:

```bash
➜  babel-npm-test node --version
v20.5.0
➜  babel-npm-test npm --version
9.8.0

These packages use the GitHub registry instead of the npm registry. Therefore, remember to set the registry entry in your .npmrc file:

➜  babel-npm-test git:(main) ✗ cat ~/.npmrc | grep '@ull-esit-pl:'
@ull-esit-pl:registry=https://npm.pkg.github.com

or set an entry registry in your package.json file:

➜  babel-npm-test git:(main) ✗ jq '.registry' package.json 
"https://npm.pkg.github.com"

Then you can proceed to install the packages:

npm i -D @babel/[email protected] @ull-esit-pl/babel-plugin-left-side-plugin @ull-esit-pl/babel-plugin-left-side-support @ull-esit-pl/parser-left-side 

Your package.json devDependencies section will look similar to this:

➜ babel-left-side-npm-test git:(main) ✗ jq '.devDependencies' package.json

{
  "@babel/cli": "^7.10.1",
  "@ull-esit-pl/babel-plugin-left-side-plugin": "latest",
  "@ull-esit-pl/babel-plugin-left-side-support": "latest",
  "@ull-esit-pl/parser-left-side": "latest"
}

Compiling the code

To compile the example above add a babel.config.js to your workspace folder:

➜ babel-npm-test git:(main) cat babel.config.js

module.exports = {
  "plugins": [
    "@ull-esit-pl/babel-plugin-left-side-plugin"
  ],
}

and then compile it using the installed packages:

  babel-npm-test npx babel  example.js

This will output the compiled code to the console:

const {
  assign,
  functionObject
} = require("@ull-esit-pl/babel-plugin-left-side-support");
const foo = functionObject(function (bar) {
  return bar * 2;
});
assign(foo, [10], 5);
console.log(foo(10));
console.log(foo(5));

If you want to save it to a file, use the -o option.

Running

You can pipe the output to node:

➜  babel-npm-test npx babel  example.js | node  -
5
10

or alternatively, use the -o option to save the output to a file and then run it:

➜  babel-left-side-npm-test git:(main) npx babel  example.js -o example.cjs
➜  babel-left-side-npm-test git:(main) ✗ node example.cjs 
5
10

References

TODO

  • We need version numbers to control the progress
  • README.md is the one babel has. It has to change to be specific about the extension for the three packages,
  • Add -D to all install instructions and remove the version number: npm install @ull-esit-pl/babel-plugin-left-side-plugin -D
  • Do we need two separated packages for the plugin and the support? Can we have a single package?

License

MIT

About

Testing Pablo's @ull-esit-pl/parser-left-side set of packages in GitHub registry

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published