source: buchla-68k/ram/adfield.c@ e225e77

Last change on this file since e225e77 was e225e77, checked in by Thomas Lopatic <thomas@…>, 7 years ago

Added missing includes and declarations.

  • Property mode set to 100644
File size: 13.5 KB
Line 
1/*
2 =============================================================================
3 adfield.c -- assignment display field processing and cursor motion
4 Version 24 -- 1989-11-15 -- D.N. Lynx Crowe
5 =============================================================================
6*/
7
8#include "stddefs.h"
9#include "fields.h"
10#include "vsdd.h"
11#include "graphdef.h"
12#include "charset.h"
13#include "hwdefs.h"
14#include "curpak.h"
15
16#include "midas.h"
17#include "asgdsp.h"
18
19extern void select(void);
20extern int16_t whatbox(void);
21extern void nokey(void);
22extern int16_t nonf(int16_t k);
23extern int16_t stdctp4(void);
24extern void cxkstd(void);
25extern void cykstd(void);
26extern void stdmkey(void);
27extern void stddkey(int16_t k);
28
29extern int16_t et_null(int16_t n);
30extern int16_t ef_null(int16_t n);
31extern int16_t rd_null(int16_t n);
32extern int16_t nd_null(int16_t n, int16_t k);
33extern int16_t et_atab(int16_t n);
34extern int16_t ef_atab(int16_t n);
35extern int16_t rd_atab(int16_t nn);
36extern int16_t nd_atab(int16_t nn, int16_t k);
37extern int16_t et_aopt(int16_t n);
38extern int16_t ef_aopt(int16_t n);
39extern int16_t rd_aopt(int16_t nn);
40extern int16_t nd_aopt(int16_t nn, int16_t k);
41extern int16_t et_avgr(int16_t nn);
42extern int16_t ef_avgr(int16_t nn);
43extern int16_t rd_avgr(int16_t nn);
44extern int16_t nd_avgr(int16_t nn, int16_t k);
45extern int16_t et_accn(int16_t n);
46extern int16_t ef_accn(int16_t n);
47extern int16_t rd_accn(int16_t nn);
48extern int16_t nd_accn(int16_t nn, int16_t k);
49extern int16_t et_agpt(int16_t n);
50extern int16_t ef_agpt(int16_t n);
51extern int16_t rd_agpt(int16_t nn);
52extern int16_t nd_agpt(int16_t nn, int16_t k);
53extern int16_t et_agch(int16_t n);
54extern int16_t ef_agch(int16_t n);
55extern int16_t rd_agch(int16_t nn);
56extern int16_t nd_agch(int16_t nn, int16_t k);
57extern int16_t et_ains(int16_t n);
58extern int16_t ef_ains(int16_t n);
59extern int16_t rd_ains(int16_t nn);
60extern int16_t nd_ains(int16_t nn, int16_t k);
61extern int16_t et_adyn(int16_t n);
62extern int16_t ef_adyn(int16_t n);
63extern int16_t rd_adyn(int16_t nn);
64extern int16_t nd_adyn(int16_t nn, int16_t k);
65extern int16_t et_atun(int16_t n);
66extern int16_t ef_atun(int16_t n);
67extern int16_t rd_atun(int16_t nn);
68extern int16_t nd_atun(int16_t nn, int16_t k);
69extern int16_t et_aprg(int16_t n);
70extern int16_t ef_aprg(int16_t n);
71extern int16_t rd_aprg(int16_t nn);
72extern int16_t nd_aprg(int16_t nn, int16_t k);
73extern int16_t et_aint(int16_t n);
74extern int16_t ef_aint(int16_t n);
75extern int16_t rd_aint(int16_t nn);
76extern int16_t nd_aint(int16_t nn, int16_t k);
77extern int16_t et_arat(int16_t n);
78extern int16_t ef_arat(int16_t n);
79extern int16_t rd_arat(int16_t nn);
80extern int16_t nd_arat(int16_t nn, int16_t k);
81extern int16_t et_adep(int16_t n);
82extern int16_t ef_adep(int16_t n);
83extern int16_t rd_adep(int16_t nn);
84extern int16_t nd_adep(int16_t nn, int16_t k);
85
86extern void vcputsv(int16_t *obase, int16_t nw, int16_t fg, int16_t bg, int16_t row, int16_t col, int8_t *str, int16_t pitch);
87
88extern void *memset(void *vp, int8_t c, int16_t n);
89
90extern int16_t adnamsw;
91extern int16_t asgmod;
92extern int16_t astat;
93extern int16_t cmtype;
94extern int16_t cmfirst;
95extern int16_t curasg;
96extern int16_t curhold;
97extern int16_t curmop;
98extern int16_t curslim;
99extern int16_t cxval;
100extern int16_t cyval;
101extern int16_t cxrate;
102extern int16_t cyrate;
103extern int16_t hcwval;
104extern int16_t hitbox;
105extern int16_t hitcx;
106extern int16_t hitcy;
107extern int16_t stccol;
108extern int16_t stcrow;
109extern int16_t thcwval;
110extern int16_t tvcwval;
111extern int16_t vcwval;
112extern int16_t vtccol;
113extern int16_t vtcrow;
114extern int16_t vtwcol;
115extern int16_t vtwrow;
116extern int16_t vtxval;
117extern int16_t vtyval;
118
119extern int16_t crate1[];
120
121extern uint16_t *asgob;
122
123extern struct asgent asgtab[];
124
125extern struct selbox adboxes[];
126extern struct selbox *csbp;
127
128extern int16_t grp2prt[12][2];
129extern int16_t key2grp[];
130extern int16_t mctlnum[];
131extern int16_t vce2grp[];
132
133/* forward references */
134
135void adcxupd(void);
136void adcyupd(void);
137void ad_xkey(void);
138
139extern void adswin(int16_t n);
140extern void curset(struct curpak *s);
141extern void drawk2g(int16_t grp);
142extern void modasg(void);
143
144/*
145
146*/
147
148struct fet ad_fet1[] = { /* field definitions */
149
150 { 0, 9, 10, 0x0000, et_atab, ef_atab, rd_atab, nd_atab},
151
152 { 1, 1, 10, 0x0000, et_null, ef_null, rd_null, nd_null},
153
154 { 4, 10, 10, 0x0002, et_aopt, ef_aopt, rd_aopt, nd_aopt},
155
156 { 3, 9, 10, 0x0003, et_aprg, ef_aprg, rd_aprg, nd_aprg},
157
158 { 4, 15, 16, 0x0004, et_avgr, ef_avgr, rd_avgr, nd_avgr},
159 { 5, 15, 16, 0x0104, et_avgr, ef_avgr, rd_avgr, nd_avgr},
160 { 6, 15, 16, 0x0204, et_avgr, ef_avgr, rd_avgr, nd_avgr},
161 { 7, 15, 16, 0x0304, et_avgr, ef_avgr, rd_avgr, nd_avgr},
162 { 8, 15, 16, 0x0404, et_avgr, ef_avgr, rd_avgr, nd_avgr},
163 { 9, 15, 16, 0x0504, et_avgr, ef_avgr, rd_avgr, nd_avgr},
164 { 4, 21, 22, 0x0604, et_avgr, ef_avgr, rd_avgr, nd_avgr},
165 { 5, 21, 22, 0x0704, et_avgr, ef_avgr, rd_avgr, nd_avgr},
166 { 6, 21, 22, 0x0804, et_avgr, ef_avgr, rd_avgr, nd_avgr},
167 { 7, 21, 22, 0x0904, et_avgr, ef_avgr, rd_avgr, nd_avgr},
168 { 8, 21, 22, 0x0A04, et_avgr, ef_avgr, rd_avgr, nd_avgr},
169 { 9, 21, 22, 0x0B04, et_avgr, ef_avgr, rd_avgr, nd_avgr},
170
171 { 5, 35, 36, 0x0005, et_accn, ef_accn, rd_accn, nd_accn},
172 { 6, 35, 36, 0x0105, et_accn, ef_accn, rd_accn, nd_accn},
173 { 7, 35, 36, 0x0205, et_accn, ef_accn, rd_accn, nd_accn},
174 { 8, 35, 36, 0x0305, et_accn, ef_accn, rd_accn, nd_accn},
175
176 { 4, 46, 46, 0x0006, et_agpt, ef_agpt, rd_agpt, nd_agpt},
177 { 5, 46, 46, 0x0106, et_agpt, ef_agpt, rd_agpt, nd_agpt},
178 { 6, 46, 46, 0x0206, et_agpt, ef_agpt, rd_agpt, nd_agpt},
179 { 7, 46, 46, 0x0306, et_agpt, ef_agpt, rd_agpt, nd_agpt},
180 { 8, 46, 46, 0x0406, et_agpt, ef_agpt, rd_agpt, nd_agpt},
181 { 9, 46, 46, 0x0506, et_agpt, ef_agpt, rd_agpt, nd_agpt},
182 { 4, 59, 59, 0x0606, et_agpt, ef_agpt, rd_agpt, nd_agpt},
183 { 5, 59, 59, 0x0706, et_agpt, ef_agpt, rd_agpt, nd_agpt},
184 { 6, 59, 59, 0x0806, et_agpt, ef_agpt, rd_agpt, nd_agpt},
185 { 7, 59, 59, 0x0906, et_agpt, ef_agpt, rd_agpt, nd_agpt},
186 { 8, 59, 59, 0x0A06, et_agpt, ef_agpt, rd_agpt, nd_agpt},
187 { 9, 59, 59, 0x0B06, et_agpt, ef_agpt, rd_agpt, nd_agpt},
188
189 { 4, 48, 49, 0x0006, et_agch, ef_agch, rd_agch, nd_agch},
190 { 5, 48, 49, 0x0106, et_agch, ef_agch, rd_agch, nd_agch},
191 { 6, 48, 49, 0x0206, et_agch, ef_agch, rd_agch, nd_agch},
192 { 7, 48, 49, 0x0306, et_agch, ef_agch, rd_agch, nd_agch},
193 { 8, 48, 49, 0x0406, et_agch, ef_agch, rd_agch, nd_agch},
194 { 9, 48, 49, 0x0506, et_agch, ef_agch, rd_agch, nd_agch},
195 { 4, 61, 62, 0x0606, et_agch, ef_agch, rd_agch, nd_agch},
196 { 5, 61, 62, 0x0706, et_agch, ef_agch, rd_agch, nd_agch},
197 { 6, 61, 62, 0x0806, et_agch, ef_agch, rd_agch, nd_agch},
198 { 7, 61, 62, 0x0906, et_agch, ef_agch, rd_agch, nd_agch},
199 { 8, 61, 62, 0x0A06, et_agch, ef_agch, rd_agch, nd_agch},
200 { 9, 61, 62, 0x0B06, et_agch, ef_agch, rd_agch, nd_agch},
201
202 { 4, 41, 42, 0x0006, et_ains, ef_ains, rd_ains, nd_ains},
203 { 5, 41, 42, 0x0106, et_ains, ef_ains, rd_ains, nd_ains},
204 { 6, 41, 42, 0x0206, et_ains, ef_ains, rd_ains, nd_ains},
205 { 7, 41, 42, 0x0306, et_ains, ef_ains, rd_ains, nd_ains},
206 { 8, 41, 42, 0x0406, et_ains, ef_ains, rd_ains, nd_ains},
207 { 9, 41, 42, 0x0506, et_ains, ef_ains, rd_ains, nd_ains},
208 { 4, 54, 55, 0x0606, et_ains, ef_ains, rd_ains, nd_ains},
209 { 5, 54, 55, 0x0706, et_ains, ef_ains, rd_ains, nd_ains},
210 { 6, 54, 55, 0x0806, et_ains, ef_ains, rd_ains, nd_ains},
211 { 7, 54, 55, 0x0906, et_ains, ef_ains, rd_ains, nd_ains},
212 { 8, 54, 55, 0x0A06, et_ains, ef_ains, rd_ains, nd_ains},
213 { 9, 54, 55, 0x0B06, et_ains, ef_ains, rd_ains, nd_ains},
214
215 { 4, 44, 44, 0x0006, et_adyn, ef_adyn, rd_adyn, nd_adyn},
216 { 5, 44, 44, 0x0106, et_adyn, ef_adyn, rd_adyn, nd_adyn},
217 { 6, 44, 44, 0x0206, et_adyn, ef_adyn, rd_adyn, nd_adyn},
218 { 7, 44, 44, 0x0306, et_adyn, ef_adyn, rd_adyn, nd_adyn},
219 { 8, 44, 44, 0x0406, et_adyn, ef_adyn, rd_adyn, nd_adyn},
220 { 9, 44, 44, 0x0506, et_adyn, ef_adyn, rd_adyn, nd_adyn},
221 { 4, 57, 57, 0x0606, et_adyn, ef_adyn, rd_adyn, nd_adyn},
222 { 5, 57, 57, 0x0706, et_adyn, ef_adyn, rd_adyn, nd_adyn},
223 { 6, 57, 57, 0x0806, et_adyn, ef_adyn, rd_adyn, nd_adyn},
224 { 7, 57, 57, 0x0906, et_adyn, ef_adyn, rd_adyn, nd_adyn},
225 { 8, 57, 57, 0x0A06, et_adyn, ef_adyn, rd_adyn, nd_adyn},
226 { 9, 57, 57, 0x0B06, et_adyn, ef_adyn, rd_adyn, nd_adyn},
227
228 { 5, 10, 10, 0x0009, et_atun, ef_atun, rd_atun, nd_atun},
229
230 { 7, 9, 10, 0x000A, et_aint, ef_aint, rd_aint, nd_aint},
231 { 8, 9, 10, 0x000A, et_arat, ef_arat, rd_arat, nd_arat},
232 { 9, 9, 10, 0x000A, et_adep, ef_adep, rd_adep, nd_adep},
233
234 { 0, 0, 0, 0x0000, FN_NULL, FN_NULL, FN_NULL, FN_NULL}
235};
236
237/*
238
239*/
240
241int16_t adbox[][8] = { /* display box parameters */
242
243 { 1, 1, 94, 27, ACFBX00, ACBBX00, 0, 1}, /* 0 */
244 { 1, 28, 94, 40, ACFBX01, ACBBX01, 2, 1}, /* 1 */
245 { 1, 56, 94, 68, ACFBX02, ACBBX02, 4, 1}, /* 2 */
246 { 1, 42, 94, 54, ACFBX03, ACBBX03, 3, 1}, /* 3 */
247 { 96, 1, 190, 138, ACFBX04, ACBBX04, 0, 13}, /* 4 */
248 {192, 1, 302, 138, ACFBX05, ACBBX05, 0, 25}, /* 5 */
249 {304, 1, 510, 138, ACFBX06, ACBBX06, 0, 39}, /* 6 */
250 { 1, 140, 510, 348, ACFBX07, ACBBX07, 10, 1}, /* 7 */
251 { 1, 70, 38, 82, ACFBX08, ACBBX08, 5, 1}, /* 8 */
252 { 40, 70, 94, 82, ACFBX09, ACBBX09, 5, 6}, /* 9 */
253 { 1, 84, 94, 138, ACFBX10, ACBBX10, 6, 1} /* 10 */
254};
255
256int8_t *adbxlb[] = { /* display box labels */
257
258 "Asgnmnt", /* 0 */
259 "Stor/Fetch", /* 1 */
260 "MIDI out", /* 2 */
261 "PrgChng", /* 3 */
262 "Assignment", /* 4 */
263 "Assignmnt of" , /* 5 */
264 "Assignmnt of Instruments,", /* 6 */
265 "G Assignment of Keys to Groups for MIDI Port 1 G", /* 7 */
266 "", /* 8 */
267 "Tun", /* 9 */
268 "PhaseShift" /* 10 */
269};
270
271/*
272
273*/
274
275struct curpak ad_flds = {
276
277 stdctp4, /* curtype */
278 nokey, /* premove */
279 nokey, /* pstmove */
280 cxkstd, /* cx_key */
281 cykstd, /* cy_key */
282 adcxupd, /* cx_upd */
283 adcyupd, /* cy_upd */
284 nokey, /* xy_up */
285 nokey, /* xy_dn */
286 ad_xkey, /* x_key */
287 select, /* e_key */
288 stdmkey, /* m_key */
289 stddkey, /* d_key */
290 nonf, /* not_fld */
291 ad_fet1, /* curfet */
292 adboxes, /* csbp */
293 crate1, /* cratex */
294 crate1, /* cratey */
295 CT_GRAF, /* cmtype */
296 CTOX(0), /* cxval */
297 RTOY(9) /* cyval */
298};
299
300/*
301
302*/
303
304/*
305 =============================================================================
306 adcyupd() -- update cursor y location
307 =============================================================================
308*/
309
310void adcyupd(void)
311{
312 if (adnamsw) {
313
314 vtcrow = YTOR(vtyval += cyrate);
315
316 if (vtcrow > (vtwrow + 2))
317 vtyval = RTOY(vtcrow = vtwrow + 2);
318 else if (vtcrow < vtwrow)
319 vtyval = RTOY(vtcrow = vtwrow);
320
321 } else {
322
323 cyval += cyrate;
324
325 if (cyval GT (CYMAX - 1))
326 cyval = CYMAX - 1;
327 else if (cyval LT 1)
328 cyval = 1;
329 }
330}
331
332/*
333 =============================================================================
334 adcxupd() -- update cursor x location
335 =============================================================================
336*/
337
338void adcxupd(void)
339{
340 if (adnamsw) {
341
342 vtccol = XTOC(vtxval += cxrate);
343
344 if (vtccol > (vtwcol + 29))
345 vtxval = CTOX(vtccol = vtwcol + 29);
346 else if (vtccol < vtwcol)
347 vtxval = CTOX(vtccol = vtwcol);
348
349 } else {
350
351 cxval += cxrate;
352
353 if (cxval GT (CXMAX - 1))
354 cxval = CXMAX - 1;
355 else if (cxval LT 1)
356 cxval = 1;
357 }
358}
359
360/*
361
362*/
363
364/*
365 =============================================================================
366 ad_xkey() -- process the X key
367 =============================================================================
368*/
369
370void ad_xkey(void)
371{
372 register int16_t row, col, grp, i;
373
374 if (astat) {
375
376 if (whatbox()) {
377
378 row = hitcy / 14;
379 col = hitcx >> 3;
380
381 switch (hitbox) {
382
383 case 0: /* name */
384
385 if (row EQ 1) {
386
387 memset(asgtab[curasg].a_name, ' ', 16);
388 asgmod = TRUE;
389 adswin(0);
390 return; /* SUCCESS */
391
392 } else
393 return; /* FAILURE */
394 case 2: /* MIDI output port */
395
396 if ((col GE 1) AND (col LE 10)) {
397
398 curmop = 0;
399 adswin(hitbox);
400 modasg();
401 return; /* SUCCESS */
402 }
403
404 break;
405/*
406
407*/
408 case 4: /* voice to group */
409
410 if (row LT 4)
411 break;
412
413 if ((col GE 13) AND (col LE 16)) {
414
415 grp = row - 4;
416 vce2grp[grp] = -1;
417 adswin(hitbox);
418 modasg();
419 return; /* SUCCESS */
420
421 } else if ((col GE 19) AND (col LE 22)) {
422
423 grp = row + 2;
424 vce2grp[grp] = -1;
425 adswin(hitbox);
426 modasg();
427 return; /* SUCCESS */
428 }
429
430 break;
431
432 case 5: /* controller number */
433
434 if ((row LT 5) OR (row GT 8))
435 break;
436
437 if ((col EQ 35) OR (col EQ 36)) {
438
439 mctlnum[row - 5] = -1;
440 adswin(hitbox);
441 modasg();
442 return; /* SUCCESS */
443 }
444
445 break;
446/*
447
448*/
449 case 6: /* port or channel */
450
451 if (row LT 4)
452 break;
453
454 if (col EQ 46 ) {
455
456 /* port */
457
458 grp = row - 4;
459 grp2prt[grp][0] = 0;
460
461 for (i = 0; i < 88; i++)
462 key2grp[i] &= ~(0x0001 << grp);
463
464 adswin(hitbox);
465 drawk2g(grp);
466 modasg();
467 return; /* SUCCESS */
468
469 } else if ((col EQ 48) OR (col EQ 49)) {
470
471 /* channel */
472
473 grp = row - 4;
474 grp2prt[grp][1] = -1;
475 adswin(hitbox);
476 modasg();
477 return; /* SUCCESS */
478/*
479
480*/
481 } else if (col EQ 59) {
482
483 /* port */
484
485 grp = row + 2;
486 grp2prt[grp][0] = 0;
487
488 for (i = 0; i < 88; i++)
489 key2grp[i] &= ~(0x0001 << grp);
490
491 adswin(hitbox);
492 drawk2g(grp);
493 modasg();
494 return; /* SUCCESS */
495
496 } else if ((col EQ 61) OR (col EQ 62)) {
497
498 /* channel */
499
500 grp = row + 2;
501 grp2prt[grp][1] = -1;
502 adswin(hitbox);
503 modasg();
504 return; /* SUCCESS */
505 }
506
507 break;
508 }
509 }
510 }
511
512 return; /* FAILURE */
513}
514
515/*
516
517*/
518
519/*
520 =============================================================================
521 adfield() -- setup field routines for the assignment editor
522 =============================================================================
523*/
524
525void adfield(void)
526{
527 curslim = 140;
528
529 curset(&ad_flds);
530}
Note: See TracBrowser for help on using the repository browser.