Skip to content

severak/endbasic

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

266 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

The EndBASIC programming language

Build and test Health checks Deploy to staging Deploy to release

EndBASIC is an interpreter for a BASIC-like language and is inspired by Amstrad's Locomotive BASIC 1.1 and Microsoft's QuickBASIC 4.5. Like the former, EndBASIC intends to provide an interactive environment that seamlessly merges coding with immediate visual feedback. Like the latter, EndBASIC offers higher-level programming constructs and strong typing.

EndBASIC offers a simplified and restricted environment to learn the foundations of programming and focuses on features that can quickly reward the programmer. These features include things like a built-in text editor, commands to manipulate the screen, and commands to interact with the hardware of a Raspberry Pi. Implementing this kind of features has priority over others such as performance or a much richer language.

EndBASIC is written in Rust and runs both on the web and locally on a variety of operating systems and platforms, including macOS, Windows, and Linux.

EndBASIC is free software under the Apache 2.0 License.

The latest version of EndBASIC is 0.6.0 and was released on 2021-02-19.

Quick start on the web

Open EndBASIC in your browser by visiting: https://endbasic.jmmv.dev/

This should work on all major desktop browsers and on iOS. Unfortunately, there are known issues on Android at the moment.

The web interpreter runs fully locally: any programs you write are persisted in your browser's local storage and not uploaded to the cloud.

Quick start on your machine

Visit the release page to download prebuilt binaries. Once downloaded, unpack the archive and run the endbasic binary to get started.

Of course, you can also build and install EndBASIC from source by running the following command (assuming you have a Rust toolchain installed): cargo install endbasic.

Gallery

Blog posts: https://jmmv.dev/tags/endbasic/

Sample code:

  • cli/examples contains the EndBASIC demo programs. These are built into the interpreter and can be run with a command like LOAD "DEMOS:/TOUR.BAS": RUN.
  • core/examples and std/examples demonstrate how to embed the EndBASIC interpreter into your own programs.

A little demo of the interactive capabilities:

Video showing the first page of the tour and the guess demo

And a photo of an EndBASIC program controlling a Raspberry Pi:

Raspberry Pi with an EndBASIC program to control its GPIO

More information

The following documents provide more information:

Why EndBASIC?

EndBASIC started as part of my desire to teach programming to my own kids. I remember learning programming on an old Amstrad CPC 6128: the experience was unique in the sense that every command had immediate effect. Changing colors, drawing on the screen, or playing sounds were just a few keystrokes away after booting the computer, without the need to deal with separate editors and terminals. I've noticed a similar excitement in my kids when showing this to them via an emulator, so I thought I would replicate this in a more modern fashion. And here we are.

Because of this inspiration, EndBASIC's name stands for "E. and D.'s BASIC" following my kids first name initials.

About

BASIC environment with a REPL, a web interface, and RPi support written in Rust

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages

  • Rust 93.2%
  • BASIC 3.4%
  • Shell 1.8%
  • VBA 0.6%
  • JavaScript 0.4%
  • CSS 0.3%
  • Other 0.3%