An operating function (Prototype)
Go to file
Rastus Vernon 506081af01 Use DNF instead of Yum for Fedora
Yum has been deprecated in favor of DNF in the latest stable Fedora
version and is no longer part of the base system. For this reason, the
command to install dependencies on Fedora should be changed to DNF.
2015-06-18 03:26:06 -04:00
.d fix build 2014-12-03 18:40:35 -05:00
debian you can specify "any" to make this work on i386 2014-07-25 15:00:53 -04:00
extras Change copyright owner to "Urbit" 2015-06-12 01:19:54 -04:00
i plug new memory leak 2015-05-21 15:15:41 -04:00
j new pill 2015-05-19 18:14:35 -04:00
n put c errors in stack trace 2015-06-10 23:59:08 -04:00
outside Revert "Revert "Jetted scrypt"" 2015-05-03 16:31:45 -07:00
Spec Update some jet stuff, and docs 2014-11-28 12:29:10 -08:00
v ignore dry/wet directory distinction 2015-06-02 15:59:39 -04:00
w licensing and such 2015-02-10 15:13:17 -08:00
.gitattributes Treat urbit.pill as binary 2014-04-08 17:29:33 -07:00
.gitignore ignore swap files 2015-05-06 13:58:54 -07:00
.travis.yml Support for GCC and CLANG 2014-03-07 13:56:16 -05:00
LICENSE.txt MIT LICENSE 2015-02-10 12:19:37 -08:00
Makefile -T for autoboot. 2015-05-19 11:38:23 -07:00
README.markdown Use DNF instead of Yum for Fedora 2015-06-18 03:26:06 -04:00

urbit

urbit is a new programming and execution environment designed from scratch.

At present urbit is under heavy development. If you're interested in keeping in touch or following the project you can:

All of the source code is distributed under the MIT license, but is for all intents and purposes in the public domain.

Install

urbit depends on:

gcc
gmp
libsigsegv
openssl
automake
autoconf
ragel
cmake
re2c
libtool
libssl-dev (Linux only)
ncurses (Linux only)

Ubuntu or Debian

sudo apt-get install libgmp3-dev libsigsegv-dev openssl libssl-dev libncurses5-dev git make exuberant-ctags automake autoconf libtool g++ ragel cmake re2c

note: http requests are not supported on either debian wheezy or jessie due to an ssl issue

Fedora

sudo dnf install gcc gcc-c++ git gmp-devel openssl-devel openssl ncurses-devel libsigsegv-devel ctags automake autoconf libtool ragel cmake re2c

AWS

sudo yum --enablerepo epel install gcc gcc-c++ git gmp-devel openssl-devel ncurses-devel libsigsegv-devel ctags automake autoconf libtool cmake re2c

OS X - Homebrew

brew install git gmp libsigsegv openssl libtool autoconf automake cmake

OS X - Macports

sudo port install git gmp libsigsegv openssl autoconf automake cmake

Although automake/autoconf/libtool are generally installed by default, some have reported needing to uninstall and reinstall those three packages, at least with Homebrew. Your mileage may vary.

Build

Clone the repo:

git clone git://github.com/urbit/urbit.git

cd to the directory you just created:

cd urbit

Just run make:

make

Run

Inside of the urbit directory run

bin/urbit -c pier

where pier is a directory that does not exist.

All your state (an append-only log and a memory checkpoint) will live in this directory. The name of your pier doesn't matter and is not visible internally.

Begin

To begin a 32-bit planet use

:?begin

which will guide you through the setup process.

Basics

^v will switch between the task manager and the focussed process. ^x will switch between processes.

To start a process that is not yet started, run *proc from the task manager.

To connect your console to a process that has already been started, run +proc from the task manager. Note that the process must be one that supports console access, such as dojo and talk.

^d will exit the pier from the task manager. No matter how you shut your urbit down you'll be returned to exactly the same state as when you turned it off.

Talk

If talk is not running, start it with *talk from the task manager.

Use ^x to switch to the talk prompt and then run

;join ~doznec/urbit-meta

to join the urbit-meta channel. People in there are helpful.

There are four main talk commands:

;join ~urbit-name/channel

;join subscribes your main feed to a remote channel.

;create channel %name 'description'

;create creates a channel on your urbit.

;<number>

;<number> activates a previous message number, like a URL that got clipped.

;<target>

;<target> sets the target for your messages, such as ;~urbit-name for a private message.

Sysadmin

For the most part, updates to the system are automatically synced to your urbit across the network.

When we make updates to the interpreter you should be able to shut down your urbit and:

git pull origin master
make
bin/urbit pier

where pier is the name of your pier.

While the network is still young from time to time we reboot the entire thing. We call this a 'continuity breach' since we're breaking the continuity of our crypto.

When this happens you'll need to back up your data and start a fresh pier. Your original ticket will still work.

Contributing

If you're interested in contributing to urbit development come and :talk with us. We'll help you get oriented and up to speed.