1 /* gAlan - Graphical Audio Language
2 * Copyright (C) 1999 Tony Garnock-Jones
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
30 #include "generator.h"
35 #define GENERATOR_CLASS_NAME "arrmul"
36 #define GENERATOR_CLASS_PATH "Array/Multiply"
40 #define NUM_EVENT_INPUTS 2
43 #define NUM_EVENT_OUTPUTS 1
50 PRIVATE
int init_instance(Generator
*g
) {
51 Data
*data
= safe_malloc(sizeof(Data
));
60 PRIVATE
void destroy_instance(Generator
*g
) {
67 PRIVATE
void unpickle_instance(Generator
*g
, ObjectStoreItem
*item
, ObjectStore
*db
) {
68 Data
*data
= safe_malloc(sizeof(Data
));
69 ObjectStoreDatum
*array
;
74 array
= objectstore_item_get(item
, "arrmul_factor");
76 data
->len
= objectstore_item_get_double(item
, "arrmul_len", 0);
77 data
->factor
= safe_malloc( sizeof( gdouble
) * data
->len
);
78 for(i
=0; i
<data
->len
; i
++ )
79 data
->factor
[i
] = objectstore_datum_double_value(
80 objectstore_datum_array_get(array
, i
) );
83 PRIVATE
void pickle_instance(Generator
*g
, ObjectStoreItem
*item
, ObjectStore
*db
) {
85 ObjectStoreDatum
*array
;
89 array
= objectstore_datum_new_array(data
->len
);
90 objectstore_item_set_integer(item
, "arrmul_len", data
->len
);
91 objectstore_item_set(item
, "arrmul_factor", array
);
92 for (i
= 0; i
< data
->len
; i
++) {
93 objectstore_datum_array_set(array
, i
,
94 objectstore_datum_new_double( data
->factor
[i
]) );
98 PRIVATE
void evt_input_handler(Generator
*g
, AEvent
*event
) {
100 Data
*data
= g
->data
;
102 switch( event
->kind
) {
104 if( event
->d
.array
.len
!= data
->len
)
106 g_print( "arrmul dimension mismatch (data->len, event->len ) = ( %d, %d )\n", data
->len
, event
->d
.array
.len
);
109 for( i
=0; i
<data
->len
; i
++ )
110 event
->d
.array
.numbers
[i
] *= data
->factor
[i
];
112 gen_send_events(g
, EVT_OUTPUT
, -1, event
);
116 g_warning( "arrmul does not support this eventkind\n" );
121 PRIVATE
void evt_factor_handler(Generator
*g
, AEvent
*event
) {
122 Data
*data
= g
->data
;
125 switch( event
->kind
) {
127 if( event
->d
.array
.len
!= data
->len
) {
128 free( data
->factor
);
129 data
->len
= event
->d
.array
.len
;
130 data
->factor
= safe_malloc( sizeof( gdouble
) * data
->len
);
134 for( i
=0; i
<data
->len
; i
++ )
135 data
->factor
[i
] = event
->d
.array
.numbers
[i
];
139 g_warning( "arrmul does not support this eventkind\n" );
144 PRIVATE ControlDescriptor controls
[] = {
145 /* { kind, name, min,max,step,page, size,editable, is_dst,queue_number,
146 init,destroy,refresh,refresh_data }, */
147 { CONTROL_KIND_NONE
, }
150 PRIVATE
void setup_class(void) {
151 GeneratorClass
*k
= gen_new_generatorclass(GENERATOR_CLASS_NAME
, FALSE
,
152 NUM_EVENT_INPUTS
, NUM_EVENT_OUTPUTS
,
153 NULL
, NULL
, controls
,
154 init_instance
, destroy_instance
,
155 unpickle_instance
, pickle_instance
);
157 gen_configure_event_input(k
, EVT_INPUT
, "Input", evt_input_handler
);
158 gen_configure_event_input(k
, EVT_FACTOR
, "Factor", evt_factor_handler
);
159 gen_configure_event_output(k
, EVT_OUTPUT
, "Output");
161 gencomp_register_generatorclass(k
, FALSE
, GENERATOR_CLASS_PATH
,
166 PUBLIC
void init_plugin(void) {