Skip to content

EvanMcBroom/sleepy

Repository files navigation

Sleepy

A lexer and parser for the Sleep scripting language. All versions of Sleep 2.1 and below are supported.

All Sleep extensions are supported as defined in the Sleep manual. The only deviation from the language specification are "operator bridges" which must be a valid identifier for Sleepy to parse them (e.g., r'[a-zA-Z_][a-zA-Z_0-9\-]*'). This change was made to allow Sleepy to define operator precedence rules. This change should not cause any issues.

Sleepy will not tokenize Java object expressions (a.k.a, "Haphazard Object Extensions for Sleep") into their individual components because doing so would create ambiguous grammar rules. A seperate lexer may be added in the future to handle these expressions. All other Sleep statements are fully tokenized.

One issue that was encountered when developing Sleepy is that the parser in the official Sleep distribution does not conform to its corresponding documentation. Namely, it allows for missing semicolons after statements and missing commas between list items. Sleepy's parser will warn the user of these syntax errors, recover, and then continue parsing.

This project is released under an MIT license. The unit tests are included from the official Sleep distribution which is released under a BSD-3 license and copyrighted to Raphael Mudge.

The unit tests have been modified to remove profanity using the profanity checker included with the example scripts. Please excuse anything that may have been missed.