diff options
author | Jason Ekstrand <[email protected]> | 2019-03-11 21:01:34 -0500 |
---|---|---|
committer | Jason Ekstrand <[email protected]> | 2019-03-13 02:10:31 +0000 |
commit | 20c4578c5539de909e94a6acc3ad680ab2ddeca6 (patch) | |
tree | a25ab6811afc33381b731d7e687ed58ce0c2df63 | |
parent | 83fdefc06287f6c8bbb3bb5bb4ccd36d653017a3 (diff) |
glsl/list: Add a list variant of insert_after
Reviewed-by: Ian Romanick <[email protected]>
Caio Marcelo de Oliveira Filho <[email protected]>
-rw-r--r-- | src/compiler/glsl/list.h | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/src/compiler/glsl/list.h b/src/compiler/glsl/list.h index 59ed766f2e1..979f6fcc539 100644 --- a/src/compiler/glsl/list.h +++ b/src/compiler/glsl/list.h @@ -81,6 +81,12 @@ struct exec_node { * Insert a node in the list after the current node */ void insert_after(exec_node *after); + + /** + * Insert another list in the list after the current node + */ + void insert_after(struct exec_list *after); + /** * Insert a node in the list before the current node */ @@ -508,6 +514,21 @@ exec_list_append(struct exec_list *list, struct exec_list *source) } static inline void +exec_node_insert_list_after(struct exec_node *n, struct exec_list *after) +{ + if (exec_list_is_empty(after)) + return; + + after->tail_sentinel.prev->next = n->next; + after->head_sentinel.next->prev = n; + + n->next->prev = after->tail_sentinel.prev; + n->next = after->head_sentinel.next; + + exec_list_make_empty(after); +} + +static inline void exec_list_prepend(struct exec_list *list, struct exec_list *source) { exec_list_append(source, list); @@ -635,6 +656,11 @@ inline void exec_list::append_list(exec_list *source) exec_list_append(this, source); } +inline void exec_node::insert_after(exec_list *after) +{ + exec_node_insert_list_after(this, after); +} + inline void exec_list::prepend_list(exec_list *source) { exec_list_prepend(this, source); |