Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yosoyubik/tic-tac-toe
Tic-Tac-Toe for Urbit
https://github.com/yosoyubik/tic-tac-toe
arvo gall game hoon tic-tac-toe urbit
Last synced: about 2 months ago
JSON representation
Tic-Tac-Toe for Urbit
- Host: GitHub
- URL: https://github.com/yosoyubik/tic-tac-toe
- Owner: yosoyubik
- License: mit
- Created: 2018-11-05T14:20:41.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-01-07T10:36:20.000Z (almost 2 years ago)
- Last Synced: 2024-04-17T03:09:06.066Z (9 months ago)
- Topics: arvo, gall, game, hoon, tic-tac-toe, urbit
- Language: JavaScript
- Homepage: https://www.youtube.com/watch?v=cKofR65sTHM
- Size: 30.8 MB
- Stars: 15
- Watchers: 3
- Forks: 1
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# TIC-TAC-TOE for Urbit
[![Header](toe.png)](https://youtu.be/cKofR65sTHM "TIC-TAC-TOE for Urbit")
## Features
- Network multiplayer.
- Board state printed in the console.
- Notifications for incoming requests to play.
- Uses a list to keep track of incoming and outgoing subscriptions.
- Pending requests are queued and pulled after current game finishes.
- Styled text to print crosses and noughts on board, and game. notifications.
- Integration with Landscape.## Installation
In order to run your application on your ship, you will need Urbit v.0.8.0 or higher. On your Urbit ship, if you haven't already, mount your pier to Unix with `|mount %`.
Then you need to add the path to you urbit's pier in .urbitrc. The file is not provided by this repo so you need to create it manually:
```
module.exports = {
URBIT_PIERS: [
"PATH/TO/YOUR/PIER",
]
};```
You have two options to mount the game into your pier:
- ##### `npm run build`
This builds your application and copies it into your Urbit ship's desk. In your Urbit (v.0.8.0 or higher) `|commit %home` (or `%your-desk-name`) to synchronize your changes.
- ##### `npm run serve`
Builds the application and copies it into your Urbit ship's desk, watching for changes. In your Urbit (v.0.8.0 or higher) `|commit %home` (or `%your-desk-name`) to synchronize your changes.
When you make changes, the `urbit` directory will update with the compiled application and, if you're running `npm run serve`, it will automatically copy itself to your Urbit ship when you save your changes (more information on that below).
## Playing
![Playing](tie.gif)
In your urbit's Dojo, run the command:
~your-urbit:dojo> |start %toe
The list of commands are:
- `'~ship-name'`: sends request to ~ship
- Only if the prompt is `| shall we play a game?`
- `'!'`: cancels the current game. (if any, unqueues next subscription)
- `'l'`: list current subscriptions (any time during the game)
- ![list|20%](subs.png)
- `'1/1'`: board coordinates (`[1-3/1-3]`)
- Only if the prompt is `| ~zod:[X] <- ~dev:[O] |`
- `'Y/y or N/n'`: confirm/reject request to play `[Y/N]`
- Only if the prompt is:
- `| ~zod wins! continue? (Y/N) |`
- `| waiting for ~zod (!=quit) |`A web frontend is also available on your Urbit's Landscape Interface.
## In Progress
- Heavy frontend refactor