Fix several 'variable set but not used' warnings reported by GCC 6.4.1.
[kugel-rb.git] / apps / plugins / pdbox / PDa / intern / sfwrite~.c
blob6f801921ef2b80cd17490faf72d4689f6e8d0c94
1 #ifdef ROCKBOX
2 #include "plugin.h"
3 #include "../../pdbox.h"
4 #else /* ROCKBOX */
5 #include <unistd.h>
6 #include <fcntl.h>
7 #include <errno.h>
8 #include <stdio.h>
9 #include <string.h>
10 #include <unistd.h>
11 #include <sys/mman.h>
12 #include <sys/stat.h>
13 #endif /* ROCKBOX */
15 #include "../src/m_pd.h"
16 #include "../src/m_fixed.h"
17 #include "../src/g_canvas.h"
20 #define BLOCKTIME 10
22 #define MAX_CHANS 4
24 #include "sformat.h"
26 static t_class *sfwrite_class;
28 typedef struct _sfwrite
30 t_object x_obj;
31 t_symbol* filename;
32 int x_file;
34 t_int rec;
35 t_int x_channels;
36 uint32 size;
37 t_glist * x_glist;
38 t_int x_blocked;
39 t_int x_blockwarn;
40 } t_sfwrite;
43 static void sfwrite_wave_setup(t_sfwrite* x,t_wave* w)
46 strncpy(w->w_fileid,"RIFF",4); /* chunk id 'RIFF' */
47 w->w_chunksize = x->size + sizeof(t_wave) -8; /* chunk size */
48 strncpy(w->w_waveid,"WAVE",4); /* wave chunk id 'WAVE' */
49 strncpy(w->w_fmtid,"fmt ",4); /* format chunk id 'fmt '*/
50 w->w_fmtchunksize = 16; /* format chunk size */
51 w->w_fmttag = 1; /* format tag, 1 for PCM */
52 w->w_nchannels = x->x_channels; /* number of channels */
53 w->w_samplespersec = 44100; /* sample rate in hz */
54 w->w_navgbytespersec = 44100*x->x_channels*2; /* average bytes per second */
55 w->w_nblockalign = 4; /* number of bytes per sample */
56 w->w_nbitspersample = 16; /* number of bits in a sample */
57 strncpy(w->w_datachunkid,"data",4); /* data chunk id 'data'*/
58 w->w_datachunksize = x->size; /* length of data chunk */
63 static void sfwrite_close(t_sfwrite *x)
65 if (x->x_file > 0) {
66 t_wave w;
67 sfwrite_wave_setup(x,&w);
68 lseek(x->x_file,0,SEEK_SET);
69 write(x->x_file,&w,sizeof(w));
70 close(x->x_file);
72 x->x_file = -1;
76 static void sfwrite_open(t_sfwrite *x,t_symbol *filename)
78 char fname[MAXPDSTRING];
80 if (filename == &s_) {
81 post("sfwrite: open without filename");
82 return;
85 canvas_makefilename(glist_getcanvas(x->x_glist), filename->s_name,
86 fname, MAXPDSTRING);
88 x->x_blocked = 0;
89 x->filename = filename;
90 post("sfwrite: filename = %s",x->filename->s_name);
92 sfwrite_close(x);
94 if ((x->x_file = open(fname,O_RDWR | O_CREAT,0664)) < 0)
96 error("can't create %s",fname);
97 return;
100 /* skip the header */
102 lseek(x->x_file,sizeof(t_wave),SEEK_SET);
103 x->size = 0;
108 static void sfwrite_block(t_sfwrite *x, t_floatarg f)
110 x->x_blockwarn = f;
114 static void sfwrite_float(t_sfwrite *x, t_floatarg f)
116 int t = f;
117 if (t) {
118 post("sfwrite: start", f);
119 x->rec=1;
121 else {
122 post("sfwrite: stop", f);
123 x->rec=0;
129 static short out[4*64];
131 static t_int *sfwrite_perform(t_int *w)
133 t_sfwrite* x = (t_sfwrite*)(w[1]);
134 t_sample * in[4];
135 int c = x->x_channels;
136 int i,num,n;
137 short* tout = out;
138 int ret;
139 int timebefore,timeafter;
140 /* double late; unused */
142 for (i=0;i < c;i++) {
143 in[i] = (t_sample *)(w[2+i]);
146 n = num = (int)(w[2+c]);
148 /* loop */
150 if (x->rec && x->x_file) {
152 while (n--) {
153 for (i=0;i<c;i++) {
154 *tout++ = (*(in[i])++)>>(fix1-16);
158 timebefore = sys_getrealtime();
159 if ((ret =write(x->x_file,out,sizeof(short)*num*c)) < (signed int)sizeof(short)*num*c) {
160 post("sfwrite: short write %d",ret);
163 timeafter = sys_getrealtime();
164 /* late = timeafter - timebefore; unused */
166 #if 0
167 /* OK, we let only 10 ms block here */
168 if (late > BLOCKTIME && x->x_blockwarn) {
169 post("sfwrite blocked %f ms",late*1000);
170 x->x_blocked++;
171 if (x->x_blocked > x->x_blockwarn) {
172 x->rec = 0;
173 post("maximum blockcount %d reached, recording stopped (set blockcount with \"block <num>\"",x->x_blockwarn);
176 #endif
177 x->size +=64*x->x_channels*sizeof(short) ;
180 return (w+3+c);
185 static void sfwrite_dsp(t_sfwrite *x, t_signal **sp)
187 switch (x->x_channels) {
188 case 1:
189 dsp_add(sfwrite_perform, 3, x, sp[0]->s_vec,
190 sp[0]->s_n);
191 break;
192 case 2:
193 dsp_add(sfwrite_perform, 4, x, sp[0]->s_vec,
194 sp[1]->s_vec, sp[0]->s_n);
195 break;
196 case 4:
197 dsp_add(sfwrite_perform, 6, x, sp[0]->s_vec,
198 sp[1]->s_vec,
199 sp[2]->s_vec,
200 sp[3]->s_vec,
201 sp[0]->s_n);
202 break;
206 static void sfwrite_free(t_sfwrite* x)
208 sfwrite_close(x);
212 static void *sfwrite_new(t_floatarg chan)
214 t_sfwrite *x = (t_sfwrite *)pd_new(sfwrite_class);
215 t_int c = chan;
217 if (c<1 || c > MAX_CHANS) c = 1;
219 x->x_glist = (t_glist*) canvas_getcurrent();
220 x->x_channels = c--;
221 x->x_file=0;
222 x->rec = 0;
223 x->size = 0;
224 x->x_blocked = 0;
225 x->x_blockwarn = 10;
226 while (c--) {
227 inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_signal, &s_signal);
231 return (x);
234 void sfwrite_tilde_setup(void)
236 sfwrite_class = class_new(gensym("sfwrite~"), (t_newmethod)sfwrite_new, (t_method)sfwrite_free,
237 sizeof(t_sfwrite), 0,A_DEFFLOAT,0);
238 class_addmethod(sfwrite_class,nullfn,gensym("signal"), 0);
239 class_addmethod(sfwrite_class, (t_method) sfwrite_dsp, gensym("dsp"), 0);
240 class_addmethod(sfwrite_class, (t_method) sfwrite_open, gensym("open"), A_SYMBOL,A_NULL);
241 class_addmethod(sfwrite_class, (t_method) sfwrite_close, gensym("close"), 0);
242 class_addmethod(sfwrite_class, (t_method)sfwrite_block,gensym("block"),A_DEFFLOAT,0);
243 class_addfloat(sfwrite_class, sfwrite_float);