CARVIEW |
Select Language
HTTP/2 302
server: nginx
date: Fri, 08 Aug 2025 02:42:57 GMT
content-type: text/plain; charset=utf-8
content-length: 0
x-archive-redirect-reason: found capture at 20090103231706
location: https://web.archive.org/web/20090103231706/https://github.com/defunkt/bus-scheme/tree
server-timing: captures_list;dur=0.707854, exclusion.robots;dur=0.027031, exclusion.robots.policy;dur=0.011764, esindex;dur=0.019321, cdx.remote;dur=430.339994, LoadShardBlock;dur=305.183263, PetaboxLoader3.datanode;dur=147.117507, PetaboxLoader3.resolve;dur=113.748297
x-app-server: wwwb-app214
x-ts: 302
x-tr: 760
server-timing: TR;dur=0,Tw;dur=0,Tc;dur=0
set-cookie: wb-p-SERVER=wwwb-app214; path=/
x-location: All
x-rl: 0
x-na: 0
x-page-cache: MISS
server-timing: MISS
x-nid: DigitalOcean
referrer-policy: no-referrer-when-downgrade
permissions-policy: interest-cohort=()
HTTP/2 301
server: nginx
date: Fri, 08 Aug 2025 02:42:58 GMT
content-type: text/html; charset=utf-8
content-length: 114
x-archive-orig-server: nginx/0.6.26
x-archive-orig-date: Sat, 03 Jan 2009 23:17:04 GMT
x-archive-orig-connection: close
x-archive-orig-set-cookie: _github_ses=BAh7ByIKZmxhc2hJQzonQWN0aW9uQ29udHJvbGxlcjo6Rmxhc2g6OkZsYXNoSGFzaHsABjoKQHVzZWR7ADoOcmV0dXJuX3RvIhovZGNoZWxpbXNreS9mb2xsb3dlcnM%3D--059f036be6fa875d3e69c87f040fb3b5717dd81d; path=/; expires=Wed, 01 Jan 2020 08:00:00 GMT; HttpOnly
x-archive-orig-status: 301 Moved Permanently
location: https://web.archive.org/web/20090103231706/https://github.com/defunkt/bus-scheme/tree/master
x-archive-orig-x-runtime: 404ms
x-archive-orig-cache-control: no-cache
x-archive-orig-content-length: 114
cache-control: max-age=1800
memento-datetime: Sat, 03 Jan 2009 23:17:06 GMT
link: ; rel="original", ; rel="timemap"; type="application/link-format", ; rel="timegate", ; rel="first memento"; datetime="Tue, 18 Nov 2008 23:05:54 GMT", ; rel="prev memento"; datetime="Tue, 18 Nov 2008 23:05:54 GMT", ; rel="memento"; datetime="Sat, 03 Jan 2009 23:17:06 GMT", ; rel="last memento"; datetime="Sat, 03 Jan 2009 23:17:06 GMT"
content-security-policy: default-src 'self' 'unsafe-eval' 'unsafe-inline' data: blob: archive.org web.archive.org web-static.archive.org wayback-api.archive.org athena.archive.org analytics.archive.org pragma.archivelab.org wwwb-events.archive.org
x-archive-src: 52_7_20090103190611_crawl102-c/52_7_20090103231402_crawl103.arc.gz
server-timing: captures_list;dur=0.522012, exclusion.robots;dur=0.018632, exclusion.robots.policy;dur=0.008421, esindex;dur=0.012625, cdx.remote;dur=125.603428, LoadShardBlock;dur=101.635229, PetaboxLoader3.datanode;dur=146.832114, load_resource;dur=268.672939, PetaboxLoader3.resolve;dur=214.024896
x-app-server: wwwb-app214
x-ts: 301
x-tr: 519
server-timing: TR;dur=0,Tw;dur=0,Tc;dur=0
x-location: All
x-rl: 0
x-na: 0
x-page-cache: MISS
server-timing: MISS
x-nid: DigitalOcean
referrer-policy: no-referrer-when-downgrade
permissions-policy: interest-cohort=()
HTTP/2 200
server: nginx
date: Fri, 08 Aug 2025 02:42:58 GMT
content-type: text/html; charset=utf-8
x-archive-orig-server: nginx/0.6.26
x-archive-orig-date: Sat, 03 Jan 2009 23:17:06 GMT
x-archive-orig-connection: close
x-archive-orig-set-cookie: _github_ses=BAh7BzoOcmV0dXJuX3RvIhovZGNoZWxpbXNreS9mb2xsb3dlcnMiCmZsYXNoSUM6J0FjdGlvbkNvbnRyb2xsZXI6OkZsYXNoOjpGbGFzaEhhc2h7AAY6CkB1c2VkewA%3D--d66dd96065311dd351c21839320666fbd5812892; path=/; expires=Wed, 01 Jan 2020 08:00:00 GMT; HttpOnly
x-archive-orig-status: 200 OK
x-archive-orig-x-runtime: 1861ms
x-archive-orig-etag: "27f0292f79a95a97373dffd55479c69b"
x-archive-orig-cache-control: private, max-age=0, must-revalidate
x-archive-orig-content-length: 23351
x-archive-guessed-content-type: text/html
x-archive-guessed-charset: utf-8
memento-datetime: Sat, 03 Jan 2009 23:17:06 GMT
link: ; rel="original", ; rel="timemap"; type="application/link-format", ; rel="timegate", ; rel="first memento"; datetime="Sat, 03 Jan 2009 23:17:06 GMT", ; rel="memento"; datetime="Sat, 03 Jan 2009 23:17:06 GMT", ; rel="next memento"; datetime="Mon, 05 Jan 2009 08:10:44 GMT", ; rel="last memento"; datetime="Mon, 05 Jan 2009 08:10:44 GMT"
content-security-policy: default-src 'self' 'unsafe-eval' 'unsafe-inline' data: blob: archive.org web.archive.org web-static.archive.org wayback-api.archive.org athena.archive.org analytics.archive.org pragma.archivelab.org wwwb-events.archive.org
x-archive-src: 52_7_20090103190611_crawl102-c/52_7_20090103231402_crawl103.arc.gz
server-timing: captures_list;dur=0.523953, exclusion.robots;dur=0.018960, exclusion.robots.policy;dur=0.008199, esindex;dur=0.015181, cdx.remote;dur=22.895692, LoadShardBlock;dur=105.542924, PetaboxLoader3.datanode;dur=74.145917, PetaboxLoader3.resolve;dur=127.356926, load_resource;dur=105.671380
x-app-server: wwwb-app214
x-ts: 200
x-tr: 293
server-timing: TR;dur=0,Tw;dur=0,Tc;dur=0
x-location: All
x-rl: 0
x-na: 0
x-page-cache: MISS
server-timing: MISS
x-nid: DigitalOcean
referrer-policy: no-referrer-when-downgrade
permissions-policy: interest-cohort=()
content-encoding: gzip
defunkt's bus-scheme at master — GitHub
We got nominated! Help us out and vote for GitHub as Best Bootstrapped Startup of 2008. (You can vote once a day.) [ hide ]
This repository is private.
All pages are served over SSL and all pushing and pulling is done over SSH.
No one may fork, clone, or view it unless they are added as a member.
Every repository with this icon (
) is private.
Every repository with this icon (

This repository is public.
Anyone may fork, clone, or view it.
Every repository with this icon (
) is public.
Every repository with this icon (

Fork of technomancy/bus-scheme | |
Description: | a Scheme written in Ruby, but implemented on the bus! |
Homepage: | https://bus-scheme.rubyforge.org |
Clone URL: |
git://github.com/defunkt/bus-scheme.git
Give this clone URL to anyone.
git clone git://github.com/defunkt/bus-scheme.git
|
README.txt
= Bus Scheme by Phil Hagelberg (c) 2007 - 2008 https://bus-scheme.rubyforge.org == Description Bus Scheme is a Scheme written in Ruby, but implemented on the bus! Every programmer must implement Scheme as a rite of passage; this is mine. Note that at least half of the implementation of Bus Scheme must be written while on a bus. Documentation, tests, and administrivia may be accomplished elsewhere, but the majority of actual implementation code is strictly bus-driven. Bus Scheme is primarily a toy; using it for anything serious is (right now) ill-advised. Bus Scheme aims for general Scheme usefulness optimized for learning and fun. It's loosely targeting R5RS, but varies in huge ways. (For the purposes of this project we pretend that R6RS never happened.) See the file R5RS.diff for ways in which Bus Scheme differs from the standard, both things that are yet unimplemented and things that are intentionally different. == Usage $ bus # drop into the REPL $ bus -e "(do some stuff)" $ bus foo.scm # load a file == Tutorial See https://technomancy.us/104 for a "Getting Started" tutorial. == Contributing If you're looking for stuff to do, try "rake todo" Patches are welcome especially if they were written while riding a bus. If your daily commute does not involve a bus but you want to submit a patch, we may be able to work something out regarding code written on trains, ferries, or perhaps even carpool lanes. Join the mailing list to ask questions and discuss: https://rubyforge.org/mail/?group_id=5094 == What makes Bus Scheme different? Well, for starters it's implemented on the bus. No other Scheme implementation can claim this. Here are a few other things that set Bus Scheme apart: === Flexible calling syntax Taking a hint from Arc, Bus Scheme allows you to use the notation (mylist n) to access the nth place of the mylist list instead of (nth mylist n) or the (myhash key) notation to access the slot in myhash corresponding to the value of key instead of (gethash myhash key). TODO: This notation is flexible, and other data types may have their own "call behaviour" specified. === Web functionality Planned: Web and RESTful application development are part of the package. Bus Scheme uses the Rack library to allow scheme programs to serve web applications. Representations of data can be easily translated between s-expressions, HTML, and JSON. === Written in a high-level language Bus Scheme is written in Ruby, which means anyone with experience in high-level dynamic languages (like, oh, I don't know... Scheme?) should be right at home poking around at the implementation. Using Ruby allows the implementation code to remain compact and concise. Bus Scheme should run on Ruby 1.8, Ruby 1.9, Rubinius, and JRuby at least. Bus Scheme also allows you to drop into Ruby when that's convenient. TODO: allow real inline Ruby blocks instead of access via a function call. === Test-Driven Bus Scheme is written in an entirely test-driven manner. As much as possible, it tries to keep its tests written in Scheme itself, so it includes a fairly comprehensive testing suite and encourages programs to be written test-first. == Install * sudo gem install bus-scheme For the source: * git clone git://github.com/technomancy/bus-scheme.git == Todo Bus Scheme is currently missing pieces of functionality: === Parser * multiline strings * regular expressions === General * filter stacktrace * continuations * macros Failing tests for some of these are already included (commented out, mostly) in the relevant test files. === Long Term (post 1.0) * web functions (defresource and friends) * (lambda (arg1 arg2 . args) body) for rest args * string interpolation * escape sequences in strings * Ruby blocks inline? * XML literals? * optimize tail call recursion * compile to Rubinius bytecode * custom call behaviour * parse non-decimal base numbers * parse rationals, scientific, complex, and polar complex numbers == Requirements Bus Scheme should run on (at least) Ruby 1.8, Ruby 1.9, Rubinius, JRuby. Any support for Windows is entirely accidental. == Bonus Fact I haven't actually used a real Scheme yet. Everything I know about it I've gathered from reading The Little Schemer, watching the Structure and Interpretation of Computer Programs videos, and reading lots about Common Lisp and Emacs Lisp. If there are huge gaping flaws in the implementation, this is likely to be why.
This feature is coming soon. Sit tight!