diff options
-rw-r--r-- | src/apimagic.c | 28 |
1 files changed, 22 insertions, 6 deletions
diff --git a/src/apimagic.c b/src/apimagic.c index f7fbf2f..0303949 100644 --- a/src/apimagic.c +++ b/src/apimagic.c @@ -14,19 +14,35 @@ | AMGC_DRIVER_VERBOSITY_USAGE #endif -static const char vermsg[] = "%s (git://midipix.org/apimagic): " - "version %d.%d.%d.\n" - "[commit reference: %s]\n"; +static const char vermsg[] = "%s%s%s (git://midipix.org/apimagic): " + "version %s%d.%d.%d%s.\n" + "[commit reference: %s%s%s]\n"; + +static const char * const amgc_ver_color[6] = { + "\e[1m\e[35m","\e[0m", + "\e[1m\e[32m","\e[0m", + "\e[1m\e[34m","\e[0m" +}; + +static const char * const amgc_ver_plain[6] = { + "","", + "","", + "","" +}; static ssize_t apimagic_version(struct amgc_driver_ctx * dctx) { const struct amgc_source_version * verinfo; + const char * const * verclr; verinfo = amgc_source_version(); + verclr = isatty(STDOUT_FILENO) ? amgc_ver_color : amgc_ver_plain; - return fprintf(stdout,vermsg,dctx->program, - verinfo->major,verinfo->minor,verinfo->revision, - verinfo->commit); + return fprintf(stdout,vermsg, + verclr[0],dctx->program,verclr[1], + verclr[2],verinfo->major,verinfo->minor, + verinfo->revision,verclr[3], + verclr[4],verinfo->commit,verclr[5]); } static void apimagic_perform_unit_actions(struct amgc_unit_ctx * uctx) |