Lines Matching refs:ptr
281 node_trav(EditLine *el, keymacro_node_t *ptr, Char *ch, keymacro_value_t *val) in node_trav() argument
284 if (ptr->ch == *ch) { in node_trav()
286 if (ptr->next) { in node_trav()
293 return node_trav(el, ptr->next, ch, val); in node_trav()
295 *val = ptr->val; in node_trav()
296 if (ptr->type != XK_CMD) in node_trav()
298 return ptr->type; in node_trav()
302 if (ptr->sibling) { in node_trav()
304 return node_trav(el, ptr->sibling, ch, val); in node_trav()
318 node__try(EditLine *el, keymacro_node_t *ptr, const Char *str, in node__try() argument
322 if (ptr->ch != *str) { in node__try()
325 for (xm = ptr; xm->sibling != NULL; xm = xm->sibling) in node__try()
330 ptr = xm->sibling; in node__try()
334 if (ptr->next != NULL) { in node__try()
335 node__put(el, ptr->next); in node__try()
337 ptr->next = NULL; in node__try()
339 switch (ptr->type) { in node__try()
345 if (ptr->val.str) in node__try()
346 el_free(ptr->val.str); in node__try()
350 ptr->type)); in node__try()
354 switch (ptr->type = ntype) { in node__try()
356 ptr->val = *val; in node__try()
360 if ((ptr->val.str = Strdup(val->str)) == NULL) in node__try()
369 if (ptr->next == NULL) in node__try()
370 ptr->next = node__get(*str); /* setup new node */ in node__try()
371 (void) node__try(el, ptr->next, str, val, ntype); in node__try()
383 keymacro_node_t *ptr; in node__delete() local
386 ptr = *inptr; in node__delete()
388 if (ptr->ch != *str) { in node__delete()
391 for (xm = ptr; xm->sibling != NULL; xm = xm->sibling) in node__delete()
397 ptr = xm->sibling; in node__delete()
402 *inptr = ptr->sibling; in node__delete()
404 prev_ptr->sibling = ptr->sibling; in node__delete()
405 ptr->sibling = NULL; in node__delete()
406 node__put(el, ptr); in node__delete()
408 } else if (ptr->next != NULL && in node__delete()
409 node__delete(el, &ptr->next, str) == 1) { in node__delete()
410 if (ptr->next != NULL) in node__delete()
413 *inptr = ptr->sibling; in node__delete()
415 prev_ptr->sibling = ptr->sibling; in node__delete()
416 ptr->sibling = NULL; in node__delete()
417 node__put(el, ptr); in node__delete()
429 node__put(EditLine *el, keymacro_node_t *ptr) in node__put() argument
431 if (ptr == NULL) in node__put()
434 if (ptr->next != NULL) { in node__put()
435 node__put(el, ptr->next); in node__put()
436 ptr->next = NULL; in node__put()
438 node__put(el, ptr->sibling); in node__put()
440 switch (ptr->type) { in node__put()
446 if (ptr->val.str != NULL) in node__put()
447 el_free(ptr->val.str); in node__put()
450 EL_ABORT((el->el_errfile, "Bad XK_ type %d\n", ptr->type)); in node__put()
453 el_free(ptr); in node__put()
463 keymacro_node_t *ptr; in node__get() local
465 ptr = el_malloc(sizeof(*ptr)); in node__get()
466 if (ptr == NULL) in node__get()
468 ptr->ch = ch; in node__get()
469 ptr->type = XK_NOD; in node__get()
470 ptr->val.str = NULL; in node__get()
471 ptr->next = NULL; in node__get()
472 ptr->sibling = NULL; in node__get()
473 return ptr; in node__get()
491 node_lookup(EditLine *el, const Char *str, keymacro_node_t *ptr, size_t cnt) in node_lookup() argument
495 if (ptr == NULL) in node_lookup()
500 (void) node_enum(el, ptr, cnt); in node_lookup()
504 if (ptr->ch == *str) { in node_lookup()
507 KEY_BUFSIZ - cnt, ptr->ch); in node_lookup()
510 if (ptr->next != NULL) in node_lookup()
512 return (node_lookup(el, str + 1, ptr->next, in node_lookup()
521 &ptr->val, ptr->type); in node_lookup()
529 if (ptr->sibling) in node_lookup()
530 return (node_lookup(el, str, ptr->sibling, in node_lookup()
543 node_enum(EditLine *el, keymacro_node_t *ptr, size_t cnt) in node_enum() argument
556 if (ptr == NULL) { in node_enum()
565 ptr->ch); in node_enum()
566 if (ptr->next == NULL) { in node_enum()
570 keymacro_kprint(el, el->el_keymacro.buf, &ptr->val, ptr->type); in node_enum()
572 (void) node_enum(el, ptr->next, cnt + (size_t)used); in node_enum()
575 if (ptr->sibling) in node_enum()
576 (void) node_enum(el, ptr->sibling, cnt); in node_enum()