/* Copyright (c) 2002 Damien HENRY.
* For information on usage and redistribution, and for a DISCLAIMER OF ALL
* WARRANTIES, see the file, "LICENSE.txt," in this distribution.  */

/* oname2l */

#include "m_pd.h"
#include <string.h>

typedef struct s_pd_obj_oname2l
{
  t_object x_obj;
} t_pd_obj_oname2l;


void oname2l_help(t_pd_obj_oname2l *x)
{
  post(" ");
  post("oname2l v001");
  post("+ selector list :");
  post("++ help : this help !!!");
  post("++ symbol : will return a list of symbol");
  post(" ");  
}

void oname2l_symbol(t_pd_obj_oname2l *x,t_symbol *s)
{
  int i,j,l,n=1,k=0;
  t_atom *my_message ;
  char *s2split ;
  t_symbol *a_symbol ;
  t_atom *an_atom ;
  for (l=0;s->s_name[l]!=0;l++)
  {
    if (s->s_name[l]=='/') {n++;} ;
  }
  s2split = (char *)getbytes(l+1) ;
  memcpy(s2split, s->s_name, l+1) ;
  my_message  = (t_atom *)getbytes(n * sizeof(t_atom));
  an_atom = my_message ;
  for (i=0;i<n;i++)
  {
    for (j=k;(s2split[j]!='/')&&(j<l);j++) {} ;
    s2split[j]=0 ;
    a_symbol = gensym(&(s2split[k]));
    SETSYMBOL(an_atom,a_symbol);
    an_atom++;
    k=j+1;
  }
  outlet_anything(x->x_obj.ob_outlet,gensym("list"), n,my_message);
  freebytes(my_message, n * sizeof(t_atom));
  freebytes(s2split, l );
}

void oname2l_free(void) { }

t_class *oname2l_class;

void *oname2l_new(void)
{
    t_pd_obj_oname2l *x = (t_pd_obj_oname2l *)pd_new(oname2l_class);
    outlet_new(&x->x_obj, &s_float);
    return (void *)x;
}

void oname2l_setup(void)
{
    oname2l_class = class_new(gensym("oname2l"), (t_newmethod)oname2l_new,(t_method)oname2l_free, sizeof( t_pd_obj_oname2l), 0,A_DEFSYMBOL, 0);
    class_addsymbol(oname2l_class, (t_method)oname2l_symbol);
    class_addmethod(oname2l_class, (t_method)oname2l_help, gensym("help"), 0);
    class_sethelpsymbol(oname2l_class, gensym("xgui/help_oname2l"));
}