diff options
author | Georg Holzmann <grholzi@users.sourceforge.net> | 2005-11-03 20:40:40 +0000 |
---|---|---|
committer | Georg Holzmann <grholzi@users.sourceforge.net> | 2005-11-03 20:40:40 +0000 |
commit | 406758342ee046707e5426f804c7b381a0728335 (patch) | |
tree | 7e58947fa006199f05efa8fb5cf6cb932cd51586 /PDContainer/src/h_deque.cpp | |
parent | 9ca96a7b406cde99fabe2956090fef0ea820c0e2 (diff) |
additional methods: [getall(, [keys(, [values(
svn path=/trunk/externals/grh/; revision=3832
Diffstat (limited to 'PDContainer/src/h_deque.cpp')
-rwxr-xr-x | PDContainer/src/h_deque.cpp | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/PDContainer/src/h_deque.cpp b/PDContainer/src/h_deque.cpp index 6246a51..989ca51 100755 --- a/PDContainer/src/h_deque.cpp +++ b/PDContainer/src/h_deque.cpp @@ -343,6 +343,30 @@ static void h_deque_get_namespace(t_h_deque *x) post("h_deque current namespace: %s",x->hdeque->getNamespace().c_str()); } +static void h_deque_getall(t_h_deque *x) +{ + deque<Element>::iterator iter = x->hdeque->getAll().begin(); + + while(iter != x->hdeque->getAll().end()) + { + Element output = *iter; + + if(output.getLength() == 1) // symbol or float + { + if (output.getAtom()[0].a_type == A_FLOAT) + outlet_float(x->out0, output.getAtom()[0].a_w.w_float); + if (output.getAtom()[0].a_type == A_SYMBOL) + outlet_symbol(x->out0, output.getAtom()[0].a_w.w_symbol); + if (output.getAtom()[0].a_type == A_POINTER) + outlet_pointer(x->out0, output.getAtom()[0].a_w.w_gpointer); + } + if(output.getLength() > 1) // list + outlet_list(x->out0,&s_list,output.getLength(),output.getAtom()); + + iter++; + } +} + static void h_deque_print(t_h_deque *x) { x->hdeque->printAllIndex(); @@ -554,6 +578,8 @@ void h_deque_setup(void) gensym("namespace"), A_DEFSYMBOL , 0); class_addmethod(h_deque_class, (t_method)h_deque_get_namespace, gensym("getnamespace"), A_DEFFLOAT, 0); + class_addmethod(h_deque_class, (t_method)h_deque_getall, + gensym("getall"), A_DEFFLOAT, 0); class_addmethod(h_deque_class, (t_method)h_deque_print, gensym("print"), A_DEFFLOAT, 0); class_addmethod(h_deque_class, (t_method)h_deque_clear, |