X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=discover%2Fgrub2%2Fbuiltins.c;h=6ada2a64c130ae05c66c12c15753e84e0af684e2;hp=7a5d8672a6a89285bfe268732dbb57ec04892d25;hb=37bff93c8b0a71432613f41f2319dc073ca64619;hpb=f452571550b6c6016698a50c834087c0d8c7575b diff --git a/discover/grub2/builtins.c b/discover/grub2/builtins.c index 7a5d867..6ada2a6 100644 --- a/discover/grub2/builtins.c +++ b/discover/grub2/builtins.c @@ -5,8 +5,9 @@ #include #include #include -#include +#include +#include "discover/parser.h" #include "grub2.h" @@ -123,7 +124,47 @@ static int builtin_search(struct grub2_script *script, return 0; } -static bool builtin_test_op(int argc, char **argv, int *consumed) +static bool builtin_test_op_file(struct grub2_script *script, char op, + const char *file) +{ + bool result; + int len, rc; + char *buf; + + rc = parser_request_file(script->ctx, script->ctx->device, + file, &buf, &len); + if (rc) + return false; + + switch (op) { + case 's': + /* -s: return true if file exists and has non-zero size */ + result = len > 0; + break; + case 'f': + /* -f: return true if file exists */ + result = true; + break; + default: + result = false; + + } + + talloc_free(buf); + return result; +} + +static bool builtin_test_op_dir(struct grub2_script *script, char op, + const char *dir) +{ + if (op != 'd') + return false; + + return parser_check_dir(script->ctx, script->ctx->device, dir) == 0; +} + +static bool builtin_test_op(struct grub2_script *script, + int argc, char **argv, int *consumed) { char *op; @@ -171,10 +212,14 @@ static bool builtin_test_op(int argc, char **argv, int *consumed) return strlen(a1) != 0; } - /* todo: implement file checks */ if (!strcmp(op, "-s") || !strcmp(op, "-f")) { *consumed = 2; - return false; + return builtin_test_op_file(script, op[1], a1); + } + + if (!strcmp(op, "-d")) { + *consumed = 2; + return builtin_test_op_dir(script, op[1], a1); } } @@ -183,7 +228,7 @@ static bool builtin_test_op(int argc, char **argv, int *consumed) return strlen(op) > 0; } -static int builtin_test(struct grub2_script *script __attribute__((unused)), +static int builtin_test(struct grub2_script *script, void *data __attribute__((unused)), int argc, char *argv[]) { @@ -222,7 +267,7 @@ static int builtin_test(struct grub2_script *script __attribute__((unused)), continue; } - rc = builtin_test_op(argc, argv, &consumed); + rc = builtin_test_op(script, argc, argv, &consumed); if (not) { rc = !rc; not = false; @@ -256,6 +301,14 @@ static int builtin_nop(struct grub2_script *script __attribute__((unused)), return 0; } +extern int builtin_load_env(struct grub2_script *script, + void *data __attribute__((unused)), + int argc, char *argv[]); +int builtin_save_env(struct grub2_script *script, + void *data __attribute__((unused)), + int argc, char *argv[]); + + static struct { const char *name; grub2_function fn; @@ -296,6 +349,14 @@ static struct { .name = "false", .fn = builtin_false, }, + { + .name = "load_env", + .fn = builtin_load_env, + }, + { + .name = "save_env", + .fn = builtin_save_env, + }, }; static const char *nops[] = {