From 977e997fd37ec5f16f4af55605c6a2083413ac40 Mon Sep 17 00:00:00 2001
From: Miller Puckette <msp@ucsd.edu>
Date: Wed, 13 Aug 2008 16:20:09 -0700
Subject: [PATCH] search allows partial word matches bug fixes

---
 doc/5.reference/cpole~-help.pd | 62 +++++++++++++++++-----------------
 doc/5.reference/rpole~-help.pd | 12 +++----
 src/g_editor.c                 | 28 ++++++---------
 src/m_binbuf.c                 | 28 ++++++++++-----
 src/s_audio_pa.c               |  3 --
 src/s_path.c                   |  6 ++--
 src/s_stuff.h                  |  2 +-
 src/u_main.tk                  | 23 ++++++-------
 8 files changed, 81 insertions(+), 83 deletions(-)

diff --git a/doc/5.reference/cpole~-help.pd b/doc/5.reference/cpole~-help.pd
index e0df0339f..f3ecbaa5f 100644
--- a/doc/5.reference/cpole~-help.pd
+++ b/doc/5.reference/cpole~-help.pd
@@ -1,24 +1,8 @@
-#N canvas 281 13 533 567 12;
+#N canvas -10 52 610 611 12;
 #X obj 54 90 osc~ 100;
 #X msg 62 117 clear;
-#X obj 79 547 lop~;
-#X text 10 550 see also:;
-#X text 333 549 updated for Pd version-0.38;
-#X obj 86 497 rzero~;
-#X obj 37 517 cpole~;
-#X obj 37 497 rpole~;
-#X obj 135 497 rzero_rev~;
-#X obj 86 517 czero~;
-#X obj 135 517 czero_rev~;
-#X text 213 497 real;
-#X text 212 518 complex;
-#X text 34 481 1-pole;
-#X text 83 481 1-zero;
-#X text 133 481 1-zero \, reversed;
-#X text 59 466 summary of raw filters:;
-#X text 73 300 y[n] = y[n-1] + a[n] * x[n];
 #X text 12 369 The transfer function is H(Z) = 1/(1 - aZ^-1).;
-#X text 106 116 <-- clear internal state to zero;
+#X text 115 116 <-- clear internal state to zero;
 #N canvas 168 90 498 357 test 0;
 #X obj 76 78 osc~;
 #X floatatom 76 55 5 0 0 0 - - -;
@@ -84,18 +68,17 @@
 #X connect 28 0 9 1;
 #X connect 29 0 28 0;
 #X restore 459 483 pd test;
-#X text 113 550 etc.: user-friendly filters;
 #X text 10 387 (Pd also provides a suite of user-friendly filters.
 This and other raw filters are provided for situations which the user-friendly
 ones can't handle. See Chapter 8 of http://crca.ucsd.edu/~msp/techniques
 for an introduction to the necessary theory.);
 #X obj 52 7 cpole~;
 #X text 114 7 complex one-pole (recursive) filter \, raw;
-#X text 118 91 <-- signal to filter (real part);
-#X text 117 173 <-- signal to filter (imaginary part);
+#X text 132 93 <-- signal to filter (real part);
+#X text 130 173 <-- signal to filter (imaginary part);
 #X obj 84 172 sig~;
 #X obj 115 197 sig~;
-#X text 149 199 <-- filter coefficient (real part);
+#X text 162 199 <-- filter coefficient (real part);
 #X obj 145 219 sig~;
 #X obj 53 244 cpole~ 0.9 0.4;
 #X text 159 246 <-- creation arguments initialize filter;
@@ -104,16 +87,33 @@ for an introduction to the necessary theory.);
 #X text 11 320 where y[n] is the output \, x[n] the input \, and a[n]
 the filter coefficient (all complex numbers). The filter is unstable
 if/when |a[n]|>1.;
-#X text 8 31 Cpole~ filters a complex audio signal (first two inlets)
+#X text 12 27 Cpole~ filters a complex audio signal (first two inlets)
 via a one-pole filter \, whose coefficients are controlled by creation
 arguments or by another complex audio signal (remaining two inlets).
 ;
-#X text 150 144 <-- set internal state (real&imaginary parts);
+#X text 171 143 <-- set internal state (real&imaginary parts);
 #X msg 64 143 set 0.6 0.8;
-#X text 179 221 <-- filter coefficient (imaginary part);
-#X connect 0 0 31 0;
-#X connect 1 0 31 0;
-#X connect 27 0 31 1;
-#X connect 28 0 31 2;
-#X connect 30 0 31 3;
-#X connect 38 0 31 0;
+#X text 190 221 <-- filter coefficient (imaginary part);
+#X text 73 300 y[n] = x[n] + a[n] * y[n-1];
+#X obj 97 566 lop~;
+#X text 11 566 see also:;
+#X obj 96 497 rzero~;
+#X obj 36 519 cpole~;
+#X obj 36 497 rpole~;
+#X obj 156 497 rzero_rev~;
+#X obj 96 519 czero~;
+#X obj 156 519 czero_rev~;
+#X text 255 497 real;
+#X text 254 520 complex;
+#X text 33 481 1-pole;
+#X text 93 481 1-zero;
+#X text 143 481 1-zero \, reversed;
+#X text 58 466 summary of raw filters:;
+#X text 137 566 etc.: user-friendly filters;
+#X text 343 583 updated for Pd version 0.42;
+#X connect 0 0 14 0;
+#X connect 1 0 14 0;
+#X connect 10 0 14 1;
+#X connect 11 0 14 2;
+#X connect 13 0 14 3;
+#X connect 21 0 14 0;
diff --git a/doc/5.reference/rpole~-help.pd b/doc/5.reference/rpole~-help.pd
index 011a2b5d1..76d976901 100644
--- a/doc/5.reference/rpole~-help.pd
+++ b/doc/5.reference/rpole~-help.pd
@@ -9,7 +9,6 @@
 #X text 8 35 Rpole~ filters an audio signal (left inlet) via a one-pole
 real filter \, whose coefficient is controlled by a creation argument
 or by an audio signal (right inlet).;
-#X text 413 511 updated for Pd version-0.38;
 #X obj 95 441 rzero~;
 #X obj 35 463 cpole~;
 #X obj 35 441 rpole~;
@@ -28,7 +27,6 @@ or by an audio signal (right inlet).;
 #X text 150 173 <-- filter coefficient (may be a signal);
 #X text 150 195 <-- creation argument initializes filter coefficient
 ;
-#X text 73 252 y[n] = y[n-1] + a[n] * x[n];
 #X text 10 310 The transfer function is H(Z) = 1/(1 - aZ^-1).;
 #X text 121 117 <-- clear internal state to zero;
 #X text 11 272 where y[n] is the output \, x[n] the input \, and a[n]
@@ -73,7 +71,9 @@ the filter coefficient. The filter is unstable if/when |a[n]|>1.;
 and other raw filters are provided for situations which the user-friendly
 ones can't handle. See Chapter 8 of http://crca.ucsd.edu/~msp/techniques
 for an introduction to the necessary theory.);
-#X connect 0 0 30 1;
-#X connect 1 0 30 0;
-#X connect 2 0 30 0;
-#X connect 21 0 30 0;
+#X text 73 252 y[n] = x[n] + a[n] * y[n-1];
+#X text 413 511 updated for Pd version 0.42;
+#X connect 0 0 28 1;
+#X connect 1 0 28 0;
+#X connect 2 0 28 0;
+#X connect 20 0 28 0;
diff --git a/src/g_editor.c b/src/g_editor.c
index ee2a76ac5..3d6eb6b26 100644
--- a/src/g_editor.c
+++ b/src/g_editor.c
@@ -1896,9 +1896,9 @@ static void canvas_menufont(t_canvas *x)
     gfxstub_new(&x2->gl_pd, &x2->gl_pd, buf);
 }
 
-static int canvas_find_index1, canvas_find_index2;
+static int canvas_find_index1, canvas_find_index2, canvas_find_wholeword;
 static t_binbuf *canvas_findbuf;
-int binbuf_match(t_binbuf *inbuf, t_binbuf *searchbuf);
+int binbuf_match(t_binbuf *inbuf, t_binbuf *searchbuf, int wholeword);
 
     /* find an atom or string of atoms */
 static int canvas_dofind(t_canvas *x, int *myindex1p)
@@ -1913,7 +1913,8 @@ static int canvas_dofind(t_canvas *x, int *myindex1p)
             t_object *ob = 0;
             if (ob = pd_checkobject(&y->g_pd))
             {
-                if (binbuf_match(ob->ob_binbuf, canvas_findbuf))
+                if (binbuf_match(ob->ob_binbuf, canvas_findbuf,
+                    canvas_find_wholeword))
                 {
                     if (myindex1 > canvas_find_index1 ||
                         myindex1 == canvas_find_index1 &&
@@ -1943,25 +1944,16 @@ static int canvas_dofind(t_canvas *x, int *myindex1p)
     return (0);
 }
 
-static void canvas_find(t_canvas *x, t_symbol *s, int ac, t_atom *av)
+static void canvas_find(t_canvas *x, t_symbol *s, t_floatarg wholeword)
 {
-    int myindex1 = 0, i;
-    for (i = 0; i < ac; i++)
-    {
-        if (av[i].a_type == A_SYMBOL)
-        {
-            if (!strcmp(av[i].a_w.w_symbol->s_name, "_semi_"))
-                SETSEMI(&av[i]);
-            else if (!strcmp(av[i].a_w.w_symbol->s_name, "_comma_"))
-                SETCOMMA(&av[i]);
-        }
-    }
+    int myindex1 = 0;
+    t_symbol *decodedsym = sys_decodedialog(s);
     if (!canvas_findbuf)
         canvas_findbuf = binbuf_new();
-    binbuf_clear(canvas_findbuf);
-    binbuf_add(canvas_findbuf, ac, av);
+    binbuf_text(canvas_findbuf, decodedsym->s_name, strlen(decodedsym->s_name));
     canvas_find_index1 = 0;
     canvas_find_index2 = -1;
+    canvas_find_wholeword = wholeword;
     canvas_whichfind = x;
     if (!canvas_dofind(x, &myindex1))
     {
@@ -2635,7 +2627,7 @@ void g_editor_setup(void)
     class_addmethod(canvas_class, (t_method)canvas_font,
         gensym("font"), A_FLOAT, A_FLOAT, A_FLOAT, A_NULL);
     class_addmethod(canvas_class, (t_method)canvas_find,
-        gensym("find"), A_GIMME, A_NULL);
+        gensym("find"), A_SYMBOL, A_FLOAT, A_NULL);
     class_addmethod(canvas_class, (t_method)canvas_find_again,
         gensym("findagain"), A_NULL);
     class_addmethod(canvas_class, (t_method)canvas_find_parent,
diff --git a/src/m_binbuf.c b/src/m_binbuf.c
index c2ebd2cad..a895bc676 100644
--- a/src/m_binbuf.c
+++ b/src/m_binbuf.c
@@ -1308,7 +1308,7 @@ static t_binbuf *binbuf_convert(t_binbuf *oldb, int maxtopd)
 }
 
     /* function to support searching */
-int binbuf_match(t_binbuf *inbuf, t_binbuf *searchbuf)
+int binbuf_match(t_binbuf *inbuf, t_binbuf *searchbuf, int wholeword)
 {
     int indexin, nmatched;
     for (indexin = 0; indexin <= inbuf->b_n - searchbuf->b_n; indexin++)
@@ -1317,15 +1317,25 @@ int binbuf_match(t_binbuf *inbuf, t_binbuf *searchbuf)
         {
             t_atom *a1 = &inbuf->b_vec[indexin + nmatched], 
                 *a2 = &searchbuf->b_vec[nmatched];
-            if (a1->a_type != a2->a_type ||
-                a1->a_type == A_SYMBOL && a1->a_w.w_symbol != a2->a_w.w_symbol
-                    ||
-                a1->a_type == A_FLOAT && a1->a_w.w_float != a2->a_w.w_float
-                    ||
-                a1->a_type == A_DOLLAR && a1->a_w.w_index != a2->a_w.w_index
-                    ||
-                a1->a_type == A_DOLLSYM && a1->a_w.w_symbol != a2->a_w.w_symbol)
+            if (a1->a_type == A_SEMI || a1->a_type == A_COMMA)
+            {
+                if (a2->a_type != a1->a_type)
                     goto nomatch;
+            }
+            else if (a1->a_type == A_FLOAT || a1->a_type == A_DOLLAR)
+            {
+                if (a2->a_type != a1->a_type || 
+                    a1->a_w.w_float != a2->a_w.w_float)
+                        goto nomatch;
+            }
+            else if (a1->a_type == A_SYMBOL || a1->a_type == A_DOLLSYM)
+            {
+                if ((a2->a_type != A_SYMBOL && a2->a_type == A_DOLLSYM)
+                    || (wholeword && a1->a_w.w_symbol != a2->a_w.w_symbol)
+                    || (!wholeword &&  !strstr(a1->a_w.w_symbol->s_name,
+                                        a2->a_w.w_symbol->s_name)))
+                        goto nomatch;
+            }           
         }
         return (1);
     nomatch: ;
diff --git a/src/s_audio_pa.c b/src/s_audio_pa.c
index 85816ee76..c346b3368 100644
--- a/src/s_audio_pa.c
+++ b/src/s_audio_pa.c
@@ -25,9 +25,6 @@ static int pa_inchans, pa_outchans;
 static float *pa_soundin, *pa_soundout;
 static t_audiocallback pa_callback;
 
-#define MAX_PA_CHANS 32
-#define MAX_SAMPLES_PER_FRAME MAX_PA_CHANS * DEFDACBLKSIZE
-
 int pa_foo;
 
 static int pa_lowlevel_callback(const void *inputBuffer,
diff --git a/src/s_path.c b/src/s_path.c
index ef4411844..fb1814dd0 100644
--- a/src/s_path.c
+++ b/src/s_path.c
@@ -419,9 +419,9 @@ int sys_rcfile(void)
 
     for (i = 1; i < NUMARGS-1; i++)
     {
-        if (fscanf(file, "%999s", buf) < 0)
+        if (fscanf(file, "%998s", buf) < 0)
             break;
-        buf[1000] = 0;
+        buf[999] = 0;
         if (!(rcargv[i] = malloc(strlen(buf) + 1)))
             goto cleanup;
         strcpy(rcargv[i], buf);
@@ -437,7 +437,7 @@ int sys_rcfile(void)
     fclose(file);
     if (sys_verbose)
     {
-        if (rcargv)
+        if (rcargc)
         {
             post("startup args from RC file:");
             for (i = 1; i < rcargc; i++)
diff --git a/src/s_stuff.h b/src/s_stuff.h
index 3276b00be..4af5c7543 100644
--- a/src/s_stuff.h
+++ b/src/s_stuff.h
@@ -28,7 +28,7 @@ int sys_open_absolute(const char *name, const char* ext,
     char *dirresult, char **nameresult, unsigned int size, int bin, int *fdp);
 int sys_trytoopenone(const char *dir, const char *name, const char* ext,
     char *dirresult, char **nameresult, unsigned int size, int bin);
-
+t_symbol *sys_decodedialog(t_symbol *s);
 
 /* s_file.c */
 
diff --git a/src/u_main.tk b/src/u_main.tk
index 1ad84f080..aa4e425b8 100644
--- a/src/u_main.tk
+++ b/src/u_main.tk
@@ -835,16 +835,12 @@ proc menu_fixwindowmenu {name} {
 set find_canvas nobody
 set find_string ""
 set find_count 1
+set find_wholeword 1
 
 proc find_apply {name} {
-    global find_string
-    global find_canvas
-    regsub -all \; $find_string " _semi_ " find_string2
-    regsub -all \, $find_string2 " _comma_ " find_string3
-#    puts stderr [concat $find_canvas find $find_string3 \
-#       \;]
-    pd [concat $find_canvas find $find_string3 \
-        \;]
+    global find_string find_canvas find_wholeword
+    pd [concat $find_canvas find [pdtk_encodedialog $find_string] \
+        $find_wholeword \;]
     after 50 destroy $name
 }
 
@@ -853,9 +849,7 @@ proc find_cancel {name} {
 }
 
 proc menu_findobject {canvas} {
-    global find_string
-    global find_canvas
-    global find_count
+    global find_string find_canvas find_count find_wholeword
     
     set name [format ".find%d" $find_count]
     set find_count [expr $find_count + 1]
@@ -869,6 +863,9 @@ proc menu_findobject {canvas} {
 
     entry $name.entry -textvariable find_string
     pack $name.entry -side top
+    checkbutton $name.wholeword -variable find_wholeword \
+        -text {whole word} -anchor e
+    pack $name.wholeword -side bottom
 
     frame $name.buttonframe
     pack $name.buttonframe -side bottom -fill x -pady 2m
@@ -4233,7 +4230,9 @@ proc path_apply {id} {
     for {set x 0} {$x < $pd_path_count} {incr x} {
         global pd_path$x
         set this_path [set pd_path$x]
-        if {0==[string match "" $this_path]} {lappend pd_path [pdtk_encodedialog $this_path]}
+        if {0==[string match "" $this_path]} {
+            lappend pd_path [pdtk_encodedialog $this_path]
+        }
     }
 
     pd [concat pd path-dialog $pd_extrapath $pd_verbose $pd_path \;]
-- 
GitLab