rsx

command module
v0.6.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 26, 2024 License: MIT Imports: 41 Imported by: 0

README

logo

RSX: Package Risor Scripts into Go Binaries

rsx is a tool that packages your Risor scripts into a standalone Go binary, allowing for easy distribution of your applications without dependencies.

[!NOTE] RSX is currently in beta.

Features

  • Package Risor scripts into a single executable
  • Built-in Risor modules for additional functionality
  • Easy project initialization and management
  • Built-in SQLite support with FTS5
  • Ability to external Risor native modules:
import rsx

rsx.load("gh:rubiojr/risor-libs/lib/test", { branch: "main" })
  • Additional Risor Go modules included:

Pre-requisites

You need to have Go installed on your system. If you don't have it, you can download it from the official website.

Installation

Install RSX using Go:

go install --tags fts5 github.com/rubiojr/rsx@latest

Ensure that your Go bin directory is in your PATH.

Quick Start

  1. Create a new Risor project:

    rsx new myapp
    cd myapp
    
  2. Edit the main script (main.risor) to add your code:

    import rsx
    
    rsx.log("Hello from Risor!")
    
  3. Build the Go binary:

    rsx build
    

[!NOTE] rbx runs go build under the hood, so you can pass any additional environment variables to it, like GOOS, GOARCH, etc.

  1. Run your application:
    ./myapp
    # Output: Hello from Risor!
    

Project Structure

  • main.risor: The entry point of your application.
  • lib/: Directory for additional Risor modules.
  • lib/rsx.risor: Built-in RSX module with utility functions.

Adding custom Risor modules

Place any additional .risor files in the lib directory. They will be automatically available at runtime.

Adding custom Risor Go modules

External Risor Go modules are supported. To add a custom Go module, follow these steps:

Add a .modules file in the root of your project with the following format:

github.com/rubiojr/risor-modules/hello
github.com/rubiojr/risor-modules/onemore

Where each line is the Go module path used in a Go import statement.

Then, run rsx build to build the binary with the custom module.

Risor Go modules are regular Go modules that extend Risor functionality with new built-ins, like https://github.com/rubiojr/risor-modules/hello.

See related official documentation at https://risor.io/docs/contributing_modules.

The RSX Module

RSX comes with a built-in rsx module providing basic functionality. For available functions, refer to rsx.risor.

Development Workflow

During development, you can run your Risor scripts directly:

# needs main.risor as the main entry point
rsx run

Or you can use eval also:

rsx eval main.risor

This allows for faster iteration without needing to rebuild the binary.

[!NOTE] Custom native Go modules not built into RSX are not avaible with rsx run. If you are using a custom module, you will need to build the binary with rsx build to test it.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Support

For issues, questions, or contributions, please open an issue on GitHub.

Documentation

Overview

Copyright Curtis Myzie (https://risor.io) Modifications 2024 Sergio Rubio

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL