aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/param.h357
1 files changed, 0 insertions, 357 deletions
diff --git a/src/param.h b/src/param.h
deleted file mode 100644
index 0be7f5d..0000000
--- a/src/param.h
+++ /dev/null
@@ -1,357 +0,0 @@
-#include "tof.h"
-
-//#define PARAMDEBUG
-
-typedef void (*t_paramGetMethod)(void*,t_symbol**,int*,t_atom**);
-typedef void (*t_paramSaveMethod)(void*,t_binbuf*,int);
-typedef void (*t_paramGUIMethod)(void*,int*,t_atom**,t_symbol**,t_symbol**);
-//typedef void (*t_paramGUIUpdateMethod)(void*);
-
-char param_buf_temp_a[MAXPDSTRING];
-char param_buf_temp_b[MAXPDSTRING];
-char* param_separator = "/";
-
-//char PARAMECHO = 0;
-
-//struct _paramroot;
-
-typedef struct _param {
- t_symbol* root;
- t_symbol* path; //Path(name) of the param
- void* x;
- struct _param* next; //Next param
- struct _param* previous; //Previous param
- t_paramGetMethod get; //Function to get current value
- t_paramSaveMethod save; //Function to save
- t_paramGUIMethod GUI;
- // t_paramGUIUpdateMethod GUIUpdate;
- //t_symbol* send;
- //t_symbol* receive;
-} t_param;
-
-typedef struct _paramroot {
- t_symbol* root;
- t_param* params; //param list
- struct _paramroot* next; //Next paramroot
- struct _paramroot* previous; //Previous paramroot
-} t_paramroot;
-
-t_paramroot* PARAMROOTS;
-
-
-static t_paramroot* param_get_root(t_symbol* root) {
-
- if (PARAMROOTS == NULL) {
- #ifdef PARAMDEBUG
- post("Could not get...not even one root created");
- #endif
- return NULL;
- }
-
-
- // Pointer to the start of paramroots
- t_paramroot* branch = PARAMROOTS;
-
- while( branch ) {
- if ( branch->root == root) {
- #ifdef PARAMDEBUG
- post("Found root:%s",root->s_name);
- #endif
-
- return branch;
- }
- branch = branch->next;
- }
- #ifdef PARAMDEBUG
- post("Could not find root");
- #endif
- return branch;
-
-}
-
-
-static t_paramroot* param_root_attach(t_symbol* root){
-
- // Pointer to the start of paramroots
- t_paramroot* branch = PARAMROOTS;
-
- while( branch ) {
- if ( branch->root == root) {
- #ifdef PARAMDEBUG
- post("Found root:%s",root->s_name);
- #endif
-
- return branch;
- }
- if ( branch->next == NULL ) break;
- branch = branch->next;
- }
-
- // we did not find a paramroot linked to this root canvas
- // so we create it
- #ifdef PARAMDEBUG
- post("Creating root:%s",root->s_name);
- #endif
-
- // Create and add paramroot to the end
- t_paramroot* newbranch = getbytes(sizeof(*newbranch));
- newbranch->root = root;
- newbranch->next = NULL;
- newbranch->params = NULL;
-
- if (branch) {
- #ifdef PARAMDEBUG
- post("Appending it to previous roots");
- #endif
- newbranch->previous = branch;
- branch->next = newbranch;
- } else {
- #ifdef PARAMDEBUG
- post("Creating first root");
- #endif
- newbranch->previous = NULL;
- PARAMROOTS = newbranch;
- }
-
-
- return newbranch;
-
-}
-
-
-
-static t_param* get_param_list(t_symbol* root) {
-
-
- t_paramroot* branch = param_get_root(root);
- if (branch) {
-
- #ifdef PARAMDEBUG
- post("Getting params from %s",branch->root->s_name);
- if (!branch->params) post("Root contains no params");
- #endif
- return branch->params;
- }
-
- return NULL;
-
-}
-
-
-static t_symbol* param_get_name ( int ac, t_atom* av ) {
-
- if (ac && IS_A_SYMBOL(av, 0)) {
- char* name = atom_getsymbol(av)->s_name;
- if (*name == *param_separator ) {
- int length = strlen(name);
- if (name[length-1] != '_' || name[length-1] != '/') return atom_getsymbol(av);
- }
- }
- post("param names must start with a \"/\" and can not end with \
- either a \"_\" or a \"/\"!");
- return NULL;
-}
-
-
-static t_symbol* param_get_path( t_canvas* i_canvas, t_symbol* name) {
-
- char* sbuf_name = param_buf_temp_a;
- char* sbuf_temp = param_buf_temp_b;
- sbuf_name[0] = '\0';
- sbuf_temp[0] = '\0';
- //char* separator = "/";
-
-
- t_symbol* id_s = gensym("/id"); // symbol that points to "/id" symbol
-
- // arguments of the current canvas being analyzed
- int i_ac;
- t_atom * i_av;
-
- // temp pointer to the current id being added to the path
- t_symbol* id_temp;
-
- /* FIND ID AND BASEPATH */
- while( i_canvas->gl_owner) {
- // Ignore all supatches
- if ( tof_canvas_is_not_subpatch(i_canvas) ) {
- tof_get_canvas_arguments(i_canvas,&i_ac, &i_av);
- id_temp=NULL;
- //id_temp= canvas_realizedollar(i_canvas, gensym("$0"));
- int ac_a = 0;
- t_atom* av_a = NULL;
- int iter = 0;
- //found_id_flag = 0;
-
- while( tof_next_tagged_argument(*param_separator,i_ac,i_av,&ac_a,&av_a,&iter) ) {
-
- if ( IS_A_SYMBOL(av_a,0)
- && (id_s == av_a->a_w.w_symbol)
- && (ac_a > 1) ) {
- id_temp = atom_getsymbol(av_a+1);
- //id_canvas = i_canvas;
- //found_id_flag = 1;
- break;
- }
- }
-
- if (id_temp == NULL) {
-
- id_temp = tof_remove_extension(tof_get_canvas_name(i_canvas));
- }
- // if ever an /id is missing, this param is not saveable
- //if (found_id_flag == 0) saveable = 0;
-
- // Prepend newly found ID
- strcpy(sbuf_temp,sbuf_name);
- strcpy(sbuf_name, param_separator);
- strcat(sbuf_name, id_temp->s_name);
- strcat(sbuf_name,sbuf_temp);
- }
- i_canvas = i_canvas->gl_owner;
- }
-
- // If no name, the path will always end with a /
-
- if ( name != NULL) {
- strcat(sbuf_name,name->s_name);
- } else {
- //if (strlen(sbuf_name)==0)
- strcat(sbuf_name,param_separator);
- }
-
- return gensym(sbuf_name);
-
-}
-
-
-
-// root, path, ac, av, ac_g, av_g
-// From there, deduct id, path_, etc...
-
-//static struct param* register_param( t_canvas* canvas, int o_ac, t_atom* o_av) {
-
-static t_param* param_register(void* x,t_symbol* root, t_symbol* path,\
- t_paramGetMethod get, t_paramSaveMethod save, t_paramGUIMethod GUI) {
-
-
- //char *separator = "/";
-
- /* GET POINTER TO PARAMLIST FOR THAT ROOT */
- t_paramroot* branch = param_root_attach(root);
- t_param* last = branch->params;
-
- // Search for param with same path
- while( last ) {
- if ( last->path == path) {
-
- pd_error(x,"Found param with same name: %s", path->s_name);
-
- return NULL;
- }
- if ( last->next == NULL ) break;
- last = last->next;
- }
-
- // Create and add param to the end
-
- t_param* p = getbytes(sizeof(*p));
- p->root = root;
- //p->alloc = 0;
- p->path = path;
-
- // Create receive and send symbols: $0/path
- //strcpy(param_buf_temp_a,p->root->s_name);
- //strcat(param_buf_temp_a,separator);
- //strcat(param_buf_temp_a,p->path->s_name);
- //p->receive = gensym(param_buf_temp_a);
- //strcat(param_buf_temp_a,"_");
- //p->send = gensym(param_buf_temp_a);
-
- p->next = NULL;
- p->x = x;
- p->get = get;
- p->save = save;
- p->GUI = GUI;
- //p->GUIUpdate = GUIUpdate;
- //p->id = id;
- //set_param( p, ac, av);
- //p->ac_g = ac_g;
- //p->av_g = getbytes(ac_g*sizeof(*(p->av_g)));
- //tof_copy_atoms(av_g,p->av_g,ac_g);
- if (last) {
- #ifdef PARAMDEBUG
- post("Appending param");
- #endif
- p->previous = last;
- last->next = p;
- } else {
- #ifdef PARAMDEBUG
- post("Creating first param");
- #endif
- p->previous = NULL;
- branch->params = p;
- }
-
-
- return p;
-
-}
-
-static void param_unregister(t_param* p) {
-
- //post("unregistering %s", p->path->s_name);
- t_paramroot* branch = param_get_root(p->root);
- t_param* paramlist = branch->params;
-
- if ( paramlist) {
-
- //p->users = p->users - 1;
- //if ( p->users == 0 ) {
- // Remove param
- //post("Removing last param of this name");
- if (p->previous) {
- p->previous->next = p->next;
- if (p->next) p->next->previous = p->previous;
- /*
- if (p->next == NULL) {
- p->previous->next = NULL;
- } else {
- p->previous->next = p->next;
- }
- */
- } else {
- paramlist = p->next;
- if ( p->next != NULL) p->next->previous = NULL;
- }
- //freebytes(p->av, p->alloc * sizeof *(p->av) );
- //freebytes(p->av_g, p->ac_g * sizeof *(p->av_g) );
- freebytes(p, sizeof *p);
- //}
-
- // Update the params for that root
- if (paramlist == NULL) {
- if (branch->previous) {
- branch->previous->next = branch->next;
- if (branch->next) branch->next->previous = branch->previous;
- } else {
- PARAMROOTS = branch->next;
- if ( branch->next != NULL) branch->next->previous = NULL;
- }
- #ifdef PARAMDEBUG
- post("Removing root:%s",branch->root->s_name);
- #endif
- freebytes(branch, sizeof *branch);
- } else {
- branch->params = paramlist;
- }
-
- } else {
- post("Euh... no params found!");
- }
-
-
-}
-
-
-