code-immersion was created for Lee Spector's Fall 2009 course at Hampshire College, "Code Immersion". The class blog can be found at codeimmersion.i3ci.hampshire.edu. The homepage for this code is on github here.
code-immersion is a lightweight PLT Scheme framework for collaborative code-sharing, originally implemented to be run on top of drscheme. The server listens for input from clients, who send code to this machine to be dispatched to the group for their perusal and possible use; this process of group creation should (hopefully) be instructive.
code-immersion is licensed under the GNU Affero General Public License v3 (or, at your choice, higher).
This is a minimal quick-start file until a proper manual can be created.
- Open up runserver.ss in DrScheme.
- Run it.
Note: if you're running this for anything but the test of everything that's described below, note your IP; you and others will need it when you run the client/daemon. Consult operating system documentation to learn how to do this, or ask someone!
- Open up runclient.ss in DrScheme.
- Run it; answer the questions it asks.
- Open up project.ss in another window and take off!
- Follow the server instructions above.
- Follow the client/daemon instructions above (for server address, when it asks, say 'localhost').
- In the project.ss window type (help). Try all these commands and make sure they work.
- (sendtext "text")
sends text (text must be in double-quotes)
- (sendcode 'code)
sends code (you'll probably want to quote it, as demonstrated)
- (gettext "name" index)
displays text from others (name in double-quotes, index is a number)
- (getcode "name" index)
displays code from others (name in double-quotes, index is a number)
- (run "name" index)
runs code from others (name in double-quotes, index is a number)
reregisters with server; do this if you aren't getting messages others are sending
returns a list of users; do this if you need such a list (perhaps for iteration)
displays short help
displays the text of this section
To send more than one s-expression of code at once, use the form ("all" ...) where ... is replaced with your code. So, to send all three of:
(display 'foo) (newline) (display 'bar)
(sendcode '("all" (display 'foo) (newline) (display 'bar)))