X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;ds=sidebyside;f=lib%2Fecoli_node_file.c;h=001dcb6bf1ce0d2d57ab09c8c8955b6c4399ed9d;hb=6a40004beef80306d5f7dcea9febec948adf6d50;hp=fd8bef4f6c92ba241ec93d0580fcc236bb413bc8;hpb=0a2b19af9303c4a0ec05bea7afe1803a429517bf;p=protos%2Flibecoli.git diff --git a/lib/ecoli_node_file.c b/lib/ecoli_node_file.c index fd8bef4..001dcb6 100644 --- a/lib/ecoli_node_file.c +++ b/lib/ecoli_node_file.c @@ -17,8 +17,8 @@ #include #include #include -#include -#include +#include +#include #include EC_LOG_TYPE_REGISTER(node_file); @@ -38,14 +38,14 @@ struct ec_node_file { static int ec_node_file_parse(const struct ec_node *gen_node, - struct ec_parsed *state, + struct ec_parse *state, const struct ec_strvec *strvec) { (void)gen_node; (void)state; if (ec_strvec_len(strvec) == 0) - return EC_PARSED_NOMATCH; + return EC_PARSE_NOMATCH; return 1; } @@ -100,13 +100,13 @@ static int split_path(const char *path, char **dname_p, char **bname_p) static int ec_node_file_complete(const struct ec_node *gen_node, - struct ec_completed *completed, + struct ec_comp *comp, const struct ec_strvec *strvec) { struct ec_node_file *node = (struct ec_node_file *)gen_node; char *dname = NULL, *bname = NULL, *effective_dir; - struct ec_completed_item *item = NULL; - enum ec_completed_type type; + struct ec_comp_item *item = NULL; + enum ec_comp_type type; struct stat st, st2; const char *input; size_t bname_len; @@ -161,13 +161,17 @@ ec_node_file_complete(const struct ec_node *gen_node, bname_len = strlen(bname); while (1) { + int save_errno = errno; + errno = 0; de = node->readdir(dir); if (de == NULL) { - if (errno == 0) + if (errno == 0) { + errno = save_errno; goto out; - else + } else { goto fail; + } } if (!ec_str_startswith(de->d_name, bname)) @@ -208,13 +212,13 @@ ec_node_file_complete(const struct ec_node *gen_node, if (ec_asprintf(&disp_str, "%s", de->d_name) < 0) goto fail; } - if (ec_completed_add_item(completed, gen_node, &item, + if (ec_comp_add_item(comp, gen_node, &item, type, input, comp_str) < 0) goto out; /* fix the display string: we don't want to display the full * path. */ - if (ec_completed_item_set_display(item, disp_str) < 0) + if (ec_comp_item_set_display(item, disp_str) < 0) goto out; item = NULL;