npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

handel-pl-dev

v0.3.5

Published

Handel is a small procedural programming language for writting songs in browser.

Downloads

7

Readme

Handel

Handel is a small procedural programming language for writting songs in browser.

The Handel Interpreter interprets Handel programs and plays compositions in browser, thanks to Tone.js.

Try the Handel Web Editor here: Handel Web Editor

soli deo gloria

Installation

Add the below to your html document:

<script src="https://unpkg.com/handel-pl-dev"></script>

You're all set!

Alternatively install with the following:

npm i handel-pl-dev

and import Handel with the following:

import * as Handel from 'handel-pl-dev';

Usage

Example Handel Snippet

start
    chunk example 
        play E3, C3, G3 for 2b
    endchunk
    run example with sound piano, loop for 5 
finish

See the Examples folder here for example Handel programs and inspiration.

Example Using Handel In Browser

function clicked(){
    Handel.RunHandel(`
        start
            chunk example using somePlayable 
                play somePlayable 
                rest for 1b
            endchunk
            save myPlayable = Eb3 for 1b
            run example using myPlayable with sound piano, loop for 5 
        finish
    `)
}
document.addEventListener("click", clicked);

Note that you pass the Handel code into the RunHandel function Handel.RunHandel(someCode)

Additionally you can use the StopHandel function to stop a running Handel program. Handel.StopHandel

StopHandel();

This function is also globally available.

Getting started

Handel programs are contained within the start and finish keywords. Below is a complete Handel program:

start
    play E4 for 1b
finish

The program above only plays 1 note. But it's a start!

Let's play something

You can be play notes and chords using the play command. Below is an example program that plays a note, then a chord:

start
    play C#3 for 1b
    play E3, G3, A4 for 1b
finish

Note the syntax above. A play command begins with the play keyword, then a note or chord (a list of notes separated by commas) follows.

Lastly play commands need a duration. The play commands above end with 'for 1b'. This states how long the particular note or notelist (chord) should be held.

Phew! We're getting somewhere.

Let's rest

Similar to the play command, a rest can played using the rest command. Below is an example program that rests for 1 beat then plays a note for 2 beats.

start
    rest for 1b
    play G5 for 2b
finish

But are there Variables?

tl;dr Here is some example usage of variables in Handel

save myplayable = E4, F4, G3 for 3b
save myduration = for 1b

play myplayable
rest myduration

You can declare Variables in Handel. Variables store two builtin types in Handel: Playables and Durations.

We've already seen Playables above. Playables are a note or notelist (chord) followed by a duration. Here are some example playables.

Bb3 for 1b
D#6, E#6, G3 for 1b

no promises that the above chord sounds pleasing to the ear :p

Durations are the keyword for followed by a beat.

A beat is any whole number followed by the letter 'b'

All together, here some example durations:

for 1b
for 2b
for 16b
for 32b

Finally variables!

To store a playable or a duration use the save keyword, followed by a variable name, an equal sign and a playable or a duration.

Variable name must contain only lowercase letters, and no numbers. Variable names must also not be any of the reserved keywords in Handel. (See the Reserved Keywords section below).

Below is an example program using variables.

start
    save myplayablenote = E2 for 2b
    save myrest = for 2b

    play myplayablenote
    rest myrest
    play myplayablenote
    rest myrest
finish

Note: in Handel all variables are constants

OK! So far so good!

Blocks loops

Handel (v0.2.0 and greater) supports block loops. Block loops begin with the block keyword and end with the endblock keyword and the amount of times a block should loop (a loop customization).

Here is an example of a block loop in Handel.

block 
    play C3, E3, G3 for 1b 
    play D3, F3, A3 for 1b 
endblock loop for 10 

Block loops use the global scope, if used globally, or use the scope of the chunk they are in.

Block loops are blocking (no pun intended), and should not be confused with Handel's procedures (chunks).

More on procedures below.

Procedures (I thought this was a procedural programming language?)

Procedures in Handel are called chunks. You can conceptualize a chunk as a song track. When ran, chunks play at the same time as other run chunks and the global track. Chunks must begin with the chunk keyword and end with the endchunk keyword.

Below is an example program with a kick drum and a piano, playing together.

start
    chunk backbeat using myplayable
        play myplayable 
    endchunk

    chunk mykeys 
        play E3, G3, A3 for 1b
        play G3, A2, C3 for 1b
        play F3, A3, C3 for 1b
        play D3, F2, A3 for 1b
    endchunk

    run mykeys with sound piano, loop for 2

    save myplayable = A1 for 1b

    run backbeat using myplayable with sound kick, loop for 8
finish

Both the 'backbeat' chunk and the 'mykeys' chunk above play together (not one after the other). This behavior allows multitrack songs to be created with Handel.

Note that each chunk has its own scope.

More on procedures (chunks) and their syntax

Procedure declaration (creating chunks)

As noted above you can create chunks with the chunk keyword. The name of the chunk (the chunk name) follows the keyword.

This chunk name must be all lowercase letters, no numbers and cannot be one of Handel's reserved keywords. (See the Reserved Keywords section below).

After the chunk name, you can optionally add parameters. A list of comma separated parameters can follow the using keyword.

Together you get the following: chunk somechunkname using someparam, anotherparam

After the optional parameter list, you can add a body to the chunk. This is a function body (what you would like to happen when the chunk is ran).

Lastly the chunk must be ended with the endchunk keyword.

Running Procedures

You can run a chunk using the run keyword.

To run a chunk use the run command followed by the name of the chunk.

If the chunk has parameters, a you must use a matching number of comma separated arguments.

Here is an example running two chunks. One chunk requires arguments the other does not.

start
    chunk noargs
        play C3 for 1b
    endchunk

    chunk withtwoargs using argone, argtwo
        play argone
        play argtwo
    endchunk

    run noargs
    save somevar = Cb4 for 1b
    run withtwoargs using E3 for 1b,  somevar
finish

Note that saved variables, playables, or durations, can be used as arguments when running a chunk.

OK! Now to configuring a run of a chunk.

Configuring a run of a chunk

You can configure a run of chunk by adding the with keyword and a comma separated list of customizations to the end of a run command.

There are three main customizations: bpm, sound, and loop.

You can use bpm keyword to set the bpm of a run of a chunk.

For example bpm 120

You can use the sound keyword to set the instrument of a run of a chunk.

For example sound piano

The current available sounds to choose from are: piano, synth, casio, kick, snare, hihat

You can use the loop keyword to set the amount of times the run of a chunk shoud loop for.

For example loop for 10

All together you can configure a run of a chunk as follows:

start
    chunk withargs using somechord 
        play somechord 
    endchunk

    run withargs using E3, G3, F3 for 1b with bpm 100, loop for 8, sound piano 
finish

Above we've got a chord, played with a piano, looping 8 times, with a bpm of 100!

Reference

Note: A musical note. 7 octaves are available.

C3
Eb2
G#7

Notelist: A list of notes. Together this list of notes forms a chord. (6 notes maximum).

C2, E2, G2
C4, Eb4, G#3

Beat: A number of beats. A whole number followed by the character 'b'.

1b
20b

Duration: An expression that represents the amount of beats to play or hold for.

for 1b
for 2b

Playable: A note or a notelist, followed by a duration.

C1, F1, E1, D1, for 1b
D1 for 2b

play: A command to play a note or notelist for a given duration. Play commands can also take a loop customization.

play C1, F1, E1, D1, for 1b
play D1 for 2b 
play E3 for 2b loop for 5

rest: A command to rest for a given duration.

rest for 1b
rest for 2b

save: A command to save a variable (see above section on variables for more details). Only playabes and durations can be saved in variables.

save myplayable = E2 for 1b
save myduration = for 1b

block: Used to declare a loop. (see above section on block loops for more details)

block
    play Gb3 for 2b
    rest for 2b
endblock loop for 10

chunk: Used to declare a procedure. (see above section on procedures for more details)

chunk mybassline
    play G1 for 2b
endchunk

using: Used to prepend a list of paramaters for a chunk.

chunk mypiano using nicechord
    play nicechord 
endchunk

run: Used to run a chunk. (see above section on running procedures for more details).

run mypiano using E2, C#2 for 1b 

with: Used to customize a given run of a chunk. (see section on procedures above for more details)

run mybassline with bpm 115

bpm: beats per minute (bpms are best synced when under 1000). loop: amount of times to loop sound: instrument to use. Follows the with keyword.

run mybassline with bpm 90, loop for 2, sound kick

Sounds: possible sounds that can be used to customize a run of a chunk. (piano, guitar, synth, casio, kick, snare, hihat)

Reserved Keywords

start

finish

play

rest

save

block

endblock

chunk

endchunk

using

run

with

bpm

loop

sound

piano

synth

casio

guitar

kick

snare

All note names are reserved keywords, ex. C4, Bb1. For this reason use only lowercase letters with no numbers in variable names.