-
Notifications
You must be signed in to change notification settings - Fork 29
Home
Welcome to the Scarpe wiki!
Scarpe is a reimplementation of Shoes using Webview and a modular backend. Shoes is a friendly little Ruby-based API. It's designed to make UI apps, full of windows and lists and text, in the same way that Ruby on Rails is designed to make web applications that run on a server and use a browser.
- Scarpe/Shoes Incompatibilities
- Shoes Implementations
- Web Archaeology - various online sources of Shoes-related information
"Where do I start? What's a good first issue?" Glad you asked!
Some eternal good first issues:
- Write tests!
- Write applications!
- Get examples to work!
- Write documentation!
- Fix bugs! - for this you can jump right in or check the good first issue tag
Eventually you can get into all kinds of interesting things. Make progress on getting Hackety-Hack running? Write a new display service? Get a new platform working? Make progress in a major direction? Up to you.
Scarpe is a project to reimplement Shoes, and also a Webview-based display service. Lacci is the name of the display-independent Shoes DSL that was created as part of all this. There's also Scarpe-Wasm, a Webassembly-based display service that relies on Lacci, but not on Scarpe-the-Webview-display-service. Frankly, we need a better name for Scarpe overall, or else for the Webview display service.
There are a lot of common, reusable components in Scarpe. For instance, there's no reason another display service couldn't use the same modular logger as in Scarpe-Webview, or the same simple printout logger from Scarpe-Wasm. Scarpe-Webview and Scarpe-Wasm share a lot of common pieces, such as the Ruby-based HTML-rendering DSL and the YAML-based segmented file format. These common reusable components are included in Scarpe-Components. That way a display service can include Scarpe-Components, choose which pieces to use and require the appropriate gems to make them work. Lacci and Scarpe-Components are kept intentionally very low in dependencies so that a display service can use just a few pieces from them without depending on gems with native extensions or library dependencies like Nokogiri or Bloops.
"Scarpe" means "shoes" in Italian, while "lacci" means "laces" or "shoelaces." "Scarpe-Components" is ancient Etruscan for "spiders" (no, not really.)
Video walkthrough of the Scarpe code, June 2023
- Display Service Separation
- Shoes and Display Events - includes some sync/async discussion
- Event Loops
- Timeouts and handlers - the restrictions of a cooperative evented approach
Why Shoes? Why Scarpe? Why _why?
This includes older Shoes API research, things that are true in some Shoes implementations but not others, and of course also things that are broadly true including in Scarpe.
- The Shoes API as we understand it
- Shoes, Slots and Self
- Shoes API Research
- Shoes Classic contained Bloopsaphone and various other not-visual-UX APIs
- Possible Libraries/Platforms
- For underlying libraries: Layout and Vector APIs