v0.1; add -v flag to print version info and /version file for client to know the version as well

This commit is contained in:
Iris Lightshard 2021-10-17 17:41:18 -06:00
parent 30603241cb
commit ca2e5b8e13
Signed by: Iris Lightshard
GPG key ID: 3B7FBC22144E6398
3 changed files with 22 additions and 2 deletions

View file

@ -39,6 +39,8 @@ This is the working structure of the 9p filesystem:
* `/grandom`: Read-only, get a random number from 0 to 99 -- These are doled out on a per-realm basis, and the number stays the same until everyone in the realm has had a chance to read it. If you've already read it this round or aren't in a realm, it will be empty. * `/grandom`: Read-only, get a random number from 0 to 99 -- These are doled out on a per-realm basis, and the number stays the same until everyone in the realm has had a chance to read it. If you've already read it this round or aren't in a realm, it will be empty.
* `/version`: Read-only, outputs the version of the `xrxs` server.
### realm format ### realm format
Each realm directory on the server should have the following files: Each realm directory on the server should have the following files:

View file

@ -11,6 +11,7 @@ typedef enum {
SCOPE, SCOPE,
RANDOM, RANDOM,
GRANDOM, GRANDOM,
VERSION
} FileType; } FileType;
typedef struct Aux { typedef struct Aux {

View file

@ -17,6 +17,8 @@
#include "realm.h" #include "realm.h"
#include "user.h" #include "user.h"
char version[] = "0.1";
int chatty9p = 0; int chatty9p = 0;
static Tree* tree; static Tree* tree;
@ -524,6 +526,13 @@ void read_grandom(Req* r) {
respond(r, nil); respond(r, nil);
} }
void read_version(Req* r) {
char buf[16];
sprintf(buf, "%s\n", version);
readstr(r, buf);
respond(r, nil);
}
void xrxs_read(Req* r) { void xrxs_read(Req* r) {
Aux* a = r->fid->file->aux; Aux* a = r->fid->file->aux;
switch (a->type) { switch (a->type) {
@ -559,6 +568,9 @@ void xrxs_read(Req* r) {
case GRANDOM: case GRANDOM:
read_grandom(r); read_grandom(r);
break; break;
case VERSION:
read_version(r);
break;
default: default:
respond(r, nil); respond(r, nil);
break; break;
@ -610,12 +622,17 @@ void threadmain(int argc, char* argv[]) {
if (scmp(argv[i], "-d")) { if (scmp(argv[i], "-d")) {
chatty9p = 1; chatty9p = 1;
} }
if (scmp(argv[i], "-v")) {
printf("xrxs v%s\n", version);
threadexits(0);
}
} }
fs.foreground = 1; fs.foreground = 1;
fs.tree = alloctree(nil, nil, DMDIR | 0777, fs_destroy_file); fs.tree = alloctree(nil, nil, DMDIR | 0777, fs_destroy_file);
tree = fs.tree; tree = fs.tree;
closefile(createfile(tree->root, "version", nil, 0400, create_aux(VERSION)));
closefile( closefile(
createfile(tree->root, "ctl", nil, DMAPPEND | 0600, create_aux(CTL))); createfile(tree->root, "ctl", nil, DMAPPEND | 0600, create_aux(CTL)));
closefile(createfile(tree->root, "carts", nil, 0400, create_aux(CARTS))); closefile(createfile(tree->root, "carts", nil, 0400, create_aux(CARTS)));