Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
brighterscript
Advanced tools
A superset of Roku's BrightScript language. Compiles to standard BrightScript.
The BrighterScript language provides new features and syntax enhancements to Roku's BrightScript language. Because the language is a superset of BrightScript, the parser and associated tools (VSCode integration, cli, etc...) work with standard BrightScript (.brs) files. This means you will get benefits (as described in the following section) from using the BrighterScript compiler, whether your project contains BrighterScript (.bs) files or not. The BrighterScript language transpiles to standard BrightScript, so your code is fully compatible with all roku devices.
BrighterScript adds several new features to the BrightScript language such as namespaces, classes, import statements, and more. Take a look at the language specification docs for more information.
BrighterScript Language Specification
--watch
mode.Brighterscript is in good hands:
Reduce boilerplate code and time debugging with language features like these:
public
, protected
, and private
and incorrect access will be enforced by compile-time checks.username = m.user <> invalid ? m.user.name : "not logged in"
print `Hello ${firstNameVar}`
.user = m.user ?? getDefaultUser()
userSettings = m.user?.account?.profile?.settings
Full BrighterScript support for syntax checking, validation, and intellisense is available within the Brightscript Language VSCode extension.
And if it's not enough, the plugin API allows extending the compiler to provide extra diagnostics or transformations.
The BrighterScript project is used to power the popular Brightscript Language VSCode extension, the maestro framework, and more.
Contact us if you use BrighterScript in your project and would like your logo listed above. More projects are adopting BrighterScript all the time, from using the new BrighterScript language features to simply using the compiler in their build pipeline.
The name BrighterScript is a compliment to everything that is great about Roku's awesome BrightScript language. Naming things is hard, and discoverability and recognizability are both very important. Here are the reasons we chose this name:
er
in BrighterScript represents the additional features we have added on top of BrightScripter
bits).bsconfig.json
for example. While brsconfig.json
might be more fitting for a pure BrightScript project, bsconfig.json
is so very close that you probably wouldn't think twice about it. Same with the fact that .bs
(BrighterScript) and .brs
are very similar.We want to honor BrightScript, the language that BrighterScript is based off of, and could think of no better way than to use most of its name in our name.
npm install brighterscript -g
If your project structure exactly matches Roku's, and you run the command from the root of your project, then you can do the following:
bsc
That's it! It will find all files in your BrightScript project, check for syntax and static analysis errors, and if there were no errors, it will produce a zip at ./out/project.zip
If you need to configure bsc
, you can do so in two ways:
bsc --help
in your terminal.bsconfig.json
file. See the available options below.
By default, bsc
looks for a bsconfig.json
file at the same directory that bsc
is executed. If you want to store your bsconfig.json
file somewhere else, then you should provide the --project
argument and specify the path to your bsconfig.json
file.Your project resides in a subdirectory of your workspace folder.
bsc --root-dir ./rokuSourceFiles
Run the compiler in watch mode
bsc --watch
Run the compiler in watch mode, and redeploy to the roku on every change
bsc --watch --deploy --host 192.168.1.10 --password secret_password
Use a bsconfig.json file not located at cwd
bsc --project ./some_folder/bsconfig.json
Run the compiler as a linter only (watch mode supported)
bsc --create-package false --copy-to-staging false
The presence of a bsconfig.json
file in a directory indicates that the directory is the root of a BrightScript project. The bsconfig.json
file specifies the root files and the compiler options required to compile the project. Here is a minimal example, which is recommended for new projects:
{
"rootDir": "src",
"files": [
"**/*"
],
"stagingFolderPath": "dist",
"retainStagingFolder": true,
//this flag tells BrighterScript that for every xml file, try to import a .bs file with the same name and location
"autoImportComponentScript": true,
"sourceMap": true
}
More information on the config file format may be found in the bsconfig.json documentation.
The BrighterScript compiler emits errors and warnings when it encounters potentially invalid code. Errors and warnings may also be emitted by compiler plugins, such as by the BrighterScript linter. These messages can be suppressed if needed; see the documentation.
In order for BrighterScript-transpiled projects to work as ropm modules, they need a reference to bslib (the BrightScript runtime library for BrighterScript features) in their package. As ropm
and brighterscript
become more popular, this could result in many duplicate copies of bslib.brs
.
To encourage reducing code duplication, BrighterScript has built-in support for loading bslib
from ropm. Here's how it works:
"pkg:/source/bslib.brs"
at transpile-time.bslib
as a dependency, then the BrighterScript compiler will not emit a copy of bslib at pkg:/source/bslib.brs
, and will instead use the path to the version from ropm pkg:/source/roku_modules/bslib/bslib.brs
.bslib is published to npm under the name @rokucommunity/bslib. If you use NodeJS version 12 or above, we recommend installing @rokucommunity/bslib
with the bslib
alias, as it produces smaller transpiled code (i.e. emits bslib_
prefix instead of rokucommunity_bslib_
). Here's the command to install bslib under the bslib
alias using the ropm CLI.
ropm install bslib@npm:@rokucommunity/bslib
npm aliases only work in NodeJS version 12 and above. If you're using a NodeJS version less than 12, you will need to install @rokucommunity/bslib directly without the alias. BrighterScript recognizes this pattern as well, it's just not preferred (for the reasons mentioned previously). Here's the command for that:
ropm install @rokucommunity/bslib
This project also contributes a class that aligns with Microsoft's Language Server Protocol, which makes it easy to integrate BrightScript
and BrighterScript
with any IDE that supports the protocol. We won't go into more detail here, but you can use the LanguageServer
class from this project to integrate into your IDE. The vscode-BrightScript-language extension uses this LanguageServer class to bring BrightScript
and BrighterScript
language support to Visual Studio Code.
Click here to view the changelog.
Special thanks to the brs project for its fantastic work on its blazing fast BrightScript parser which was used as the foundation for the BrighterScript parser.
FAQs
A superset of Roku's BrightScript language.
We found that brighterscript demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers 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
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.