mirror of
https://github.com/urbit/shrub.git
synced 2025-01-07 05:26:56 +03:00
vere: switches upgrade to subcommand (next
instead of --next
)
This commit is contained in:
parent
c7f970fb7b
commit
ed234bfd41
@ -107,13 +107,12 @@ _main_repath(c3_c* pax_c)
|
|||||||
return rel_c;
|
return rel_c;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* _main_getopt(): extract option map from command line.
|
/* _main_init(): initialize globals
|
||||||
*/
|
*/
|
||||||
static u3_noun
|
static void
|
||||||
_main_getopt(c3_i argc, c3_c** argv)
|
_main_init(void)
|
||||||
{
|
{
|
||||||
c3_i ch_i, lid_i;
|
u3_Host.nex_o = c3n;
|
||||||
c3_w arg_w;
|
|
||||||
|
|
||||||
u3_Host.ops_u.abo = c3n;
|
u3_Host.ops_u.abo = c3n;
|
||||||
u3_Host.ops_u.dem = c3n;
|
u3_Host.ops_u.dem = c3n;
|
||||||
@ -127,7 +126,6 @@ _main_getopt(c3_i argc, c3_c** argv)
|
|||||||
u3_Host.ops_u.has = c3y;
|
u3_Host.ops_u.has = c3y;
|
||||||
|
|
||||||
u3_Host.ops_u.net = c3y;
|
u3_Host.ops_u.net = c3y;
|
||||||
u3_Host.ops_u.nex = c3n;
|
|
||||||
u3_Host.ops_u.lit = c3n;
|
u3_Host.ops_u.lit = c3n;
|
||||||
u3_Host.ops_u.nuu = c3n;
|
u3_Host.ops_u.nuu = c3n;
|
||||||
u3_Host.ops_u.pro = c3n;
|
u3_Host.ops_u.pro = c3n;
|
||||||
@ -140,6 +138,36 @@ _main_getopt(c3_i argc, c3_c** argv)
|
|||||||
u3_Host.ops_u.puf_c = "jam";
|
u3_Host.ops_u.puf_c = "jam";
|
||||||
u3_Host.ops_u.hap_w = 50000;
|
u3_Host.ops_u.hap_w = 50000;
|
||||||
u3_Host.ops_u.kno_w = DefaultKernel;
|
u3_Host.ops_u.kno_w = DefaultKernel;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* _main_pier_run(): get pier from binary path (argv[0]), if appropriate
|
||||||
|
*/
|
||||||
|
static c3_c*
|
||||||
|
_main_pier_run(c3_c* bin_c)
|
||||||
|
{
|
||||||
|
c3_c* dir_c = 0;
|
||||||
|
c3_w len_w = strlen(bin_c);
|
||||||
|
|
||||||
|
// no args, argv[0] == $pier/.run
|
||||||
|
//
|
||||||
|
if ( (U3_BIN_ALIAS_LEN <= len_w)
|
||||||
|
&& (0 == strcmp(bin_c + (len_w - U3_BIN_ALIAS_LEN), U3_BIN_ALIAS)) )
|
||||||
|
{
|
||||||
|
bin_c = strdup(bin_c); // dirname can modify
|
||||||
|
dir_c = _main_repath(dirname(bin_c));
|
||||||
|
c3_free(bin_c);
|
||||||
|
}
|
||||||
|
|
||||||
|
return dir_c;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* _main_getopt(): extract option map from command line.
|
||||||
|
*/
|
||||||
|
static u3_noun
|
||||||
|
_main_getopt(c3_i argc, c3_c** argv)
|
||||||
|
{
|
||||||
|
c3_i ch_i, lid_i;
|
||||||
|
c3_w arg_w;
|
||||||
|
|
||||||
static struct option lop_u[] = {
|
static struct option lop_u[] = {
|
||||||
{ "arvo", required_argument, NULL, 'A' },
|
{ "arvo", required_argument, NULL, 'A' },
|
||||||
@ -168,7 +196,6 @@ _main_getopt(c3_i argc, c3_c** argv)
|
|||||||
{ "ames-port", required_argument, NULL, 'p' },
|
{ "ames-port", required_argument, NULL, 'p' },
|
||||||
{ "http-port", required_argument, NULL, c3__http },
|
{ "http-port", required_argument, NULL, c3__http },
|
||||||
{ "https-port", required_argument, NULL, c3__htls },
|
{ "https-port", required_argument, NULL, c3__htls },
|
||||||
{ "next", no_argument, NULL, c3__next },
|
|
||||||
{ "no-conn", no_argument, NULL, c3__noco },
|
{ "no-conn", no_argument, NULL, c3__noco },
|
||||||
{ "quiet", no_argument, NULL, 'q' },
|
{ "quiet", no_argument, NULL, 'q' },
|
||||||
{ "versions", no_argument, NULL, 'R' },
|
{ "versions", no_argument, NULL, 'R' },
|
||||||
@ -291,10 +318,6 @@ _main_getopt(c3_i argc, c3_c** argv)
|
|||||||
} else u3_Host.ops_u.pes_s = arg_w;
|
} else u3_Host.ops_u.pes_s = arg_w;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case c3__next: {
|
|
||||||
u3_Host.ops_u.nex = c3y;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case c3__noco: {
|
case c3__noco: {
|
||||||
u3_Host.ops_u.con = c3n;
|
u3_Host.ops_u.con = c3n;
|
||||||
break;
|
break;
|
||||||
@ -354,23 +377,10 @@ _main_getopt(c3_i argc, c3_c** argv)
|
|||||||
if ( u3_Host.ops_u.who_c != 0 ) {
|
if ( u3_Host.ops_u.who_c != 0 ) {
|
||||||
u3_Host.dir_c = strdup(1 + u3_Host.ops_u.who_c);
|
u3_Host.dir_c = strdup(1 + u3_Host.ops_u.who_c);
|
||||||
}
|
}
|
||||||
else {
|
// no trailing positional arg, argv[0] != $pier/.run, invalid command
|
||||||
c3_w len_w = strlen(argv[0]);
|
//
|
||||||
|
else if ( !(u3_Host.dir_c = _main_pier_run(argv[0])) ) {
|
||||||
// no args, argv[0] == $pier/.run
|
return c3n;
|
||||||
//
|
|
||||||
if ( (U3_BIN_ALIAS_LEN <= len_w)
|
|
||||||
&& (0 == strcmp(argv[0] + (len_w - U3_BIN_ALIAS_LEN), U3_BIN_ALIAS)) )
|
|
||||||
{
|
|
||||||
c3_c* bin_c = strdup(argv[0]);
|
|
||||||
u3_Host.dir_c = _main_repath(dirname(bin_c));
|
|
||||||
c3_free(bin_c);
|
|
||||||
}
|
|
||||||
// no args, invalid command
|
|
||||||
//
|
|
||||||
else {
|
|
||||||
return c3n;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -486,11 +496,6 @@ _main_getopt(c3_i argc, c3_c** argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( u3_Host.ops_u.nuu == c3y && u3_Host.ops_u.nex == c3y ) {
|
|
||||||
fprintf(stderr, "upgrades cannot be performed during boot\n");
|
|
||||||
return c3n;
|
|
||||||
}
|
|
||||||
|
|
||||||
return c3y;
|
return c3y;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -566,6 +571,7 @@ _cw_usage(c3_c* s)
|
|||||||
" %s info <pier> print pier info:\n"
|
" %s info <pier> print pier info:\n"
|
||||||
" %s meld <pier> deduplicate snapshot:\n"
|
" %s meld <pier> deduplicate snapshot:\n"
|
||||||
" %s pack <pier> defragment snapshot:\n"
|
" %s pack <pier> defragment snapshot:\n"
|
||||||
|
" %s next <pier> request upgrade:\n"
|
||||||
" %s queu <pier> <at-event> cue state:\n"
|
" %s queu <pier> <at-event> cue state:\n"
|
||||||
"\n run as a 'serf':\n"
|
"\n run as a 'serf':\n"
|
||||||
" %s serf <pier> <key> <flags> <cache-size> <at-event>"
|
" %s serf <pier> <key> <flags> <cache-size> <at-event>"
|
||||||
@ -573,7 +579,7 @@ _cw_usage(c3_c* s)
|
|||||||
" <ctrlc-handle>"
|
" <ctrlc-handle>"
|
||||||
#endif
|
#endif
|
||||||
"\n",
|
"\n",
|
||||||
s, s, s, s, s, s, s);
|
s, s, s, s, s, s, s, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* u3_ve_usage(): print usage and exit.
|
/* u3_ve_usage(): print usage and exit.
|
||||||
@ -1202,6 +1208,32 @@ _cw_meld(c3_i argc, c3_c* argv[])
|
|||||||
u3m_stop();
|
u3m_stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* _cw_next(); request upgrade
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
_cw_next(c3_i argc, c3_c* argv[])
|
||||||
|
{
|
||||||
|
switch ( argc ) {
|
||||||
|
case 2: {
|
||||||
|
if ( !(u3_Host.dir_c = _main_pier_run(argv[0])) ) {
|
||||||
|
fprintf(stderr, "unable to find pier\r\n");
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
} break;
|
||||||
|
|
||||||
|
case 3: {
|
||||||
|
u3_Host.dir_c = argv[2];
|
||||||
|
} break;
|
||||||
|
|
||||||
|
default: {
|
||||||
|
fprintf(stderr, "invalid command\r\n");
|
||||||
|
exit(1);
|
||||||
|
} break;
|
||||||
|
}
|
||||||
|
|
||||||
|
u3_Host.nex_o = c3y;
|
||||||
|
}
|
||||||
|
|
||||||
/* _cw_pack(); compact memory, save, and exit.
|
/* _cw_pack(); compact memory, save, and exit.
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
@ -1232,6 +1264,7 @@ _cw_utils(c3_i argc, c3_c* argv[])
|
|||||||
// [?(%grab %mass) dir=@t] :: gc
|
// [?(%grab %mass) dir=@t] :: gc
|
||||||
// [%info dir=@t] :: print
|
// [%info dir=@t] :: print
|
||||||
// [%meld dir=@t] :: deduplicate
|
// [%meld dir=@t] :: deduplicate
|
||||||
|
// [?(%next %upgrade) dir=@t] :: upgrade
|
||||||
// [%pack dir=@t] :: defragment
|
// [%pack dir=@t] :: defragment
|
||||||
// [%queu dir=@t eve=@ud] :: cue state
|
// [%queu dir=@t eve=@ud] :: cue state
|
||||||
// :: :: ipc:
|
// :: :: ipc:
|
||||||
@ -1241,27 +1274,33 @@ _cw_utils(c3_i argc, c3_c* argv[])
|
|||||||
// NB: don't print to anything other than stderr;
|
// NB: don't print to anything other than stderr;
|
||||||
// other streams may be used for ipc.
|
// other streams may be used for ipc.
|
||||||
//
|
//
|
||||||
if ( (2 < argc) && 4 == strlen(argv[1]) ) {
|
c3_m mot_m = 0;
|
||||||
c3_m mot_m;
|
|
||||||
{
|
if ( 2 <= argc ) {
|
||||||
c3_c* s = argv[1]; mot_m = c3_s4(s[0], s[1], s[2], s[3]);
|
if ( 4 == strlen(argv[1]) ) {
|
||||||
|
c3_c* s = argv[1];
|
||||||
|
mot_m = c3_s4(s[0], s[1], s[2], s[3]);
|
||||||
}
|
}
|
||||||
|
else if ( 0 == strcmp(argv[1], "upgrade") ) {
|
||||||
switch ( mot_m ) {
|
mot_m = c3__next;
|
||||||
case c3__cram: _cw_cram(argc, argv); return 1;
|
|
||||||
|
|
||||||
case c3__mass:
|
|
||||||
case c3__grab: _cw_grab(argc, argv); return 1;
|
|
||||||
|
|
||||||
case c3__info: _cw_info(argc, argv); return 1;
|
|
||||||
case c3__meld: _cw_meld(argc, argv); return 1;
|
|
||||||
case c3__pack: _cw_pack(argc, argv); return 1;
|
|
||||||
case c3__queu: _cw_queu(argc, argv); return 1;
|
|
||||||
|
|
||||||
case c3__serf: _cw_serf_commence(argc, argv); return 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch ( mot_m ) {
|
||||||
|
case c3__cram: _cw_cram(argc, argv); return 1;
|
||||||
|
|
||||||
|
case c3__mass:
|
||||||
|
case c3__grab: _cw_grab(argc, argv); return 1;
|
||||||
|
|
||||||
|
case c3__info: _cw_info(argc, argv); return 1;
|
||||||
|
case c3__meld: _cw_meld(argc, argv); return 1;
|
||||||
|
case c3__next: _cw_next(argc, argv); return 2; // continue on
|
||||||
|
case c3__pack: _cw_pack(argc, argv); return 1;
|
||||||
|
case c3__queu: _cw_queu(argc, argv); return 1;
|
||||||
|
|
||||||
|
case c3__serf: _cw_serf_commence(argc, argv); return 1;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1274,16 +1313,32 @@ main(c3_i argc,
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_main_init();
|
||||||
|
|
||||||
c3_c* bin_c = strdup(argv[0]);
|
c3_c* bin_c = strdup(argv[0]);
|
||||||
|
|
||||||
// Parse options.
|
// parse for subcommands
|
||||||
//
|
//
|
||||||
if ( _cw_utils(argc, argv) ) {
|
switch ( _cw_utils(argc, argv) ) {
|
||||||
return 0;
|
default: c3_assert(0);
|
||||||
}
|
|
||||||
else if ( c3n == _main_getopt(argc, argv) ) {
|
// no matching subcommand, parse arguments
|
||||||
u3_ve_usage(argc, argv);
|
//
|
||||||
return 1;
|
case 0: {
|
||||||
|
if ( c3n == _main_getopt(argc, argv) ) {
|
||||||
|
u3_ve_usage(argc, argv);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
} break;
|
||||||
|
|
||||||
|
// ran subcommand
|
||||||
|
case 1: {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// found subcommand, continue
|
||||||
|
//
|
||||||
|
case 2: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -310,7 +310,6 @@
|
|||||||
c3_c* puk_c; // -Y, scry result filename
|
c3_c* puk_c; // -Y, scry result filename
|
||||||
c3_c* puf_c; // -Z, scry result format
|
c3_c* puf_c; // -Z, scry result format
|
||||||
c3_o con; // run conn
|
c3_o con; // run conn
|
||||||
c3_o nex; // upgrade
|
|
||||||
} u3_opts;
|
} u3_opts;
|
||||||
|
|
||||||
/* u3_host: entire host.
|
/* u3_host: entire host.
|
||||||
@ -323,10 +322,11 @@
|
|||||||
c3_d now_d; // event tick
|
c3_d now_d; // event tick
|
||||||
uv_loop_t* lup_u; // libuv event loop
|
uv_loop_t* lup_u; // libuv event loop
|
||||||
u3_usig* sig_u; // signal list
|
u3_usig* sig_u; // signal list
|
||||||
#if defined(U3_OS_mingw)
|
#if defined(U3_OS_mingw)
|
||||||
HANDLE cev_u; // Ctrl-C event handle
|
HANDLE cev_u; // Ctrl-C event handle
|
||||||
#endif
|
#endif
|
||||||
u3_utty* uty_u; // linked terminal list
|
u3_utty* uty_u; // linked terminal list
|
||||||
|
c3_o nex_o; // upgrade requested
|
||||||
u3_opts ops_u; // commandline options
|
u3_opts ops_u; // commandline options
|
||||||
c3_i xit_i; // exit code for shutdown
|
c3_i xit_i; // exit code for shutdown
|
||||||
u3_trac tra_u; // tracing information
|
u3_trac tra_u; // tracing information
|
||||||
|
@ -1415,13 +1415,13 @@ u3_king_done(void)
|
|||||||
|
|
||||||
// get next binary
|
// get next binary
|
||||||
//
|
//
|
||||||
if ( c3y == u3_Host.ops_u.nex ) {
|
if ( c3y == u3_Host.nex_o ) {
|
||||||
c3_c* pac_c;
|
c3_c* pac_c;
|
||||||
c3_c* ver_c;
|
c3_c* ver_c;
|
||||||
|
|
||||||
// hack to ensure we only try once
|
// hack to ensure we only try once
|
||||||
//
|
//
|
||||||
u3_Host.ops_u.nex = c3n;
|
u3_Host.nex_o = c3n;
|
||||||
|
|
||||||
pac_c = _king_get_pace();
|
pac_c = _king_get_pace();
|
||||||
|
|
||||||
@ -1437,13 +1437,13 @@ u3_king_done(void)
|
|||||||
case 0: {
|
case 0: {
|
||||||
u3l_log("vere: next (%%%s): %s\n", pac_c, ver_c);
|
u3l_log("vere: next (%%%s): %s\n", pac_c, ver_c);
|
||||||
_king_do_upgrade(pac_c, ver_c);
|
_king_do_upgrade(pac_c, ver_c);
|
||||||
|
c3_free(ver_c);
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
default: c3_assert(0);
|
default: c3_assert(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
c3_free(pac_c);
|
c3_free(pac_c);
|
||||||
c3_free(ver_c);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// copy binary into pier on boot
|
// copy binary into pier on boot
|
||||||
|
@ -1049,7 +1049,7 @@ _pier_play(u3_play* pay_u)
|
|||||||
else if ( pay_u->eve_d == log_u->dun_d ) {
|
else if ( pay_u->eve_d == log_u->dun_d ) {
|
||||||
u3_lord_save(pir_u->god_u);
|
u3_lord_save(pir_u->god_u);
|
||||||
|
|
||||||
if ( c3y == u3_Host.ops_u.nex ) {
|
if ( c3y == u3_Host.nex_o ) {
|
||||||
u3_pier_exit(pir_u);
|
u3_pier_exit(pir_u);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -1436,7 +1436,7 @@ _pier_on_lord_live(void* ptr_v)
|
|||||||
_pier_play_init(pir_u, eve_d);
|
_pier_play_init(pir_u, eve_d);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if ( c3y == u3_Host.ops_u.nex ) {
|
if ( c3y == u3_Host.nex_o ) {
|
||||||
u3_pier_exit(pir_u);
|
u3_pier_exit(pir_u);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
Loading…
Reference in New Issue
Block a user