Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/soiu/rapydscript-plugin
Babel plugin to load Python/RapydScript code
https://github.com/soiu/rapydscript-plugin
babel babel-plugin loader python rapydscript transpiler
Last synced: 21 days ago
JSON representation
Babel plugin to load Python/RapydScript code
- Host: GitHub
- URL: https://github.com/soiu/rapydscript-plugin
- Owner: soIu
- License: mit
- Created: 2021-05-06T08:40:11.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-02-15T14:30:23.000Z (almost 3 years ago)
- Last Synced: 2024-12-15T07:19:08.494Z (24 days ago)
- Topics: babel, babel-plugin, loader, python, rapydscript, transpiler
- Language: JavaScript
- Homepage:
- Size: 369 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# babel-plugin-rapydscript
Babel plugin to load Python/RapydScript code# Installation
```
npm install babel-plugin-rapydscript
```Then add 'rapydscript' to your babel plugins wether it's on babelrc, babel.config.json or if you use a bundler usually they add directives for you to add babel plugins (if the bundler use babel or is configured to use babel as a loader).
# Example Usage
In any of your JS code, require a py file:
```js
//index.js//Either ES6 import or CommonJS' require works, dynamic import is still on the work
import from_python from './test.py';
const same_object_from_python = require('./test.py');console.log(from_python === same_object_from_python);
console.log(from_python);
```And in your Python/RapydScript code:
```python
#test.pydef some_function():
print('I log some string')
return 'and return another string'
class SomeClass:
some_class_property = [1, {}]
another_property = 'could be anything'
def __init__(self):
self.some_object_property = 'not a class one'
module.exports = [some_function, SomeClass(), SomeClass.some_class_property, SomeClass().some_object_property, some_function()]
```# Known Limitation
We choose to make this module a babel plugin instead of a webpack loader because we want to target bundlers as much as possible. Unfortunately making this plugin to be compatible to all bundler forces us to make some sacrifices:
- Because most bundlers ignore loading files outside of project directory to babel loader and sometimes ignore them too in node_modules, there will be some `rapydscript-cache-*` folders that are created on project root during transpilation.
- Not only the most compatible location is on project root, but metro bundler seems to be a bitch in handling files/folders that have a dot at the start of the name. So the `rapydscript-cache-*` folders can't be hidden with dot (unix).
- Fortunately these folders will only appear at transpilation. This doesn't have major effects when building for production, but at development (watch mode) the folders will be there until you stop the dev server. Feel free to add `rapydscript-cache-*` to .gitignore to prevent acidentally adding them to your commits.# Async/Await
Because we use Kovid Goyal's [fork](https://github.com/kovidgoyal/rapydscript-ng) of RapydScript (for stability and good support, and also baselib compatibility), it still doesn't support `async def` and `await` keyword natively. We implement a nice workaround that makes async/asynchronous as a decorator:
```python
@async #Or @asynchronous if your IDE complains about the syntax
def do_something_async():
response = await fetch('/some/route')
text = await response.text()
return text
do_something_async().then(console.log)
````await` is still available as a keyword.