~ubuntu-branches/ubuntu/natty/pd-zexy/natty

« back to all changes in this revision

Viewing changes to src/blockswap~.c

  • Committer: Bazaar Package Importer
  • Author(s): Jonas Smedegaard, IOhannes m zmölnig, Jonas Smedegaard
  • Date: 2010-08-20 12:17:41 UTC
  • mfrom: (2.1.2 sid)
  • Revision ID: james.westby@ubuntu.com-20100820121741-4kxozn8b9rhee9fr
Tags: 2.2.3-1
* New upstream version

[ IOhannes m zmölnig ]
* Adopt package, on behalf of Multimedia Team.
  Closes: #546964
* Simply debian/rules with CDBS, and don't unconditionally strip
  binaries.
  Closes: #437763
* Install into /usr/lib/pd/extra/zexy/. Document usage in REAME.Debian
  and warn about change in NEWS.
* git'ify package. Add Vcs-* stanzas to control file.
* Use dpkg source format 3.0 (quilt). Drop build-dependency on quilt.

[ Jonas Smedegaard ]
* Enable CDBS copyright-check routine.
* Add copyright and licensing header to debian/rules.
* Add myself as uploader.
* Rewrite debian/copyright using rev. 135 of draft DEP5 format.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/******************************************************
 
2
 *
 
3
 * zexy - implementation file
 
4
 *
 
5
 * copyleft (c) IOhannes m zm�lnig
 
6
 *
 
7
 *   1999:forum::f�r::uml�ute:2004
 
8
 *
 
9
 *   institute of electronic music and acoustics (iem)
 
10
 *
 
11
 ******************************************************
 
12
 *
 
13
 * license: GNU General Public License v.2
 
14
 *
 
15
 ******************************************************/
 
16
 
 
17
#include "zexy.h"
 
18
 
 
19
/* ------------------------ blockswap~ ----------------------------- */
 
20
 
 
21
/* swaps a signalblock around it's center:
 
22
   {x[0], x[1], ... x[n-1]} --> {x[n-1], x[n-2], ... x[0]}
 
23
*/
 
24
 
 
25
static t_class *blockswap_class;
 
26
 
 
27
typedef struct _blockswap
 
28
{
 
29
  t_object x_obj;
 
30
  int doit;
 
31
  int blocksize;
 
32
  t_sample *blockbuffer;
 
33
} t_blockswap;
 
34
 
 
35
static void blockswap_float(t_blockswap *x, t_floatarg f)
 
36
{
 
37
  x->doit = (f != 0);
 
38
}
 
39
 
 
40
static t_int *blockswap_perform(t_int *w)
 
41
{
 
42
  t_blockswap   *x = (t_blockswap *)(w[1]);
 
43
  t_sample *in = (t_sample *)(w[2]);
 
44
  t_sample *out = (t_sample *)(w[3]);
 
45
  int N = (int)(w[4]);
 
46
  int N2=N/2;
 
47
  if (x->doit) {
 
48
    int n=N2;
 
49
    t_sample *dummy=x->blockbuffer;
 
50
    while(n--)*dummy++=*in++;
 
51
    n=N-N2;
 
52
    while(n--)*out++=*in++;
 
53
    dummy=x->blockbuffer;
 
54
    n=N2;    
 
55
    while(n--)*out++=*dummy++;
 
56
  } else while (N--) *out++=*in++;
 
57
  return (w+5);
 
58
}
 
59
 
 
60
static void blockswap_dsp(t_blockswap *x, t_signal **sp)
 
61
{
 
62
  if (x->blocksize*2<sp[0]->s_n){
 
63
    if(x->blockbuffer)freebytes(x->blockbuffer, sizeof(*x->blockbuffer)*x->blocksize);
 
64
    x->blocksize = sp[0]->s_n/2;
 
65
    x->blockbuffer = getbytes(sizeof(*x->blockbuffer)*x->blocksize);
 
66
  }
 
67
  dsp_add(blockswap_perform, 4, x, sp[0]->s_vec, sp[1]->s_vec, sp[0]->s_n);
 
68
}
 
69
 
 
70
static void blockswap_helper(t_blockswap *x)
 
71
{
 
72
  post("\n%c blockswap~-object for blockwise-swapping of a signal ", HEARTSYMBOL);
 
73
  post("'help' : view this\n"
 
74
       "signal~");
 
75
  post("outlet : signal~");
 
76
}
 
77
 
 
78
static void blockswap_free(t_blockswap *x)
 
79
{
 
80
  if(x->blockbuffer){
 
81
    freebytes(x->blockbuffer, sizeof(*x->blockbuffer)*x->blocksize);
 
82
  }
 
83
  x->blockbuffer=0;
 
84
}
 
85
 
 
86
static void *blockswap_new(void)
 
87
{
 
88
  t_blockswap *x = (t_blockswap *)pd_new(blockswap_class);
 
89
  outlet_new(&x->x_obj, gensym("signal"));
 
90
  x->doit = 1;
 
91
  x->blocksize=0;
 
92
  return (x);
 
93
}
 
94
 
 
95
void blockswap_tilde_setup(void)
 
96
{
 
97
  blockswap_class = class_new(gensym("blockswap~"), (t_newmethod)blockswap_new, (t_method)blockswap_free,
 
98
                              sizeof(t_blockswap), 0, A_NULL);
 
99
  class_addmethod(blockswap_class, nullfn, gensym("signal"), 0);
 
100
  class_addmethod(blockswap_class, (t_method)blockswap_dsp, gensym("dsp"), 0);
 
101
  
 
102
  class_addfloat(blockswap_class, blockswap_float);
 
103
  
 
104
  class_addmethod(blockswap_class, (t_method)blockswap_helper, gensym("help"), 0);
 
105
  zexy_register("blockswap~");
 
106
}