1 | /*
|
---|
2 | =============================================================================
|
---|
3 | insdflt.c -- read the default isntrument and create a C data file
|
---|
4 | Version 3 -- 1988-04-19 -- D.N. Lynx Crowe
|
---|
5 | =============================================================================
|
---|
6 | */
|
---|
7 |
|
---|
8 | #define M7CAT 1 /* so libdsp.h gets it right */
|
---|
9 |
|
---|
10 | #include "stdio.h"
|
---|
11 | #include "stddefs.h"
|
---|
12 | #include "graphdef.h"
|
---|
13 | #include "vsdd.h"
|
---|
14 |
|
---|
15 | #include "midas.h"
|
---|
16 | #include "instdsp.h"
|
---|
17 | #include "libdsp.h"
|
---|
18 |
|
---|
19 | #define LIBNAME "m7dflt.orc" /* library name */
|
---|
20 | #define THEINST 0 /* library offset: 0 = 1 */
|
---|
21 |
|
---|
22 | #define DFLTNAME "dfltins.h"
|
---|
23 | #define MAXPERL 8
|
---|
24 |
|
---|
25 | extern int errno;
|
---|
26 |
|
---|
27 | struct instdef idefs[NINORC];
|
---|
28 | struct mlibhdr ldhead;
|
---|
29 |
|
---|
30 | /* |
---|
31 |
|
---|
32 | */
|
---|
33 |
|
---|
34 | /*
|
---|
35 | =============================================================================
|
---|
36 | readit() -- read a file, with error checking
|
---|
37 | =============================================================================
|
---|
38 | */
|
---|
39 |
|
---|
40 | short
|
---|
41 | readit(fp, to, len)
|
---|
42 | register FILE *fp;
|
---|
43 | register char *to;
|
---|
44 | register long len;
|
---|
45 | {
|
---|
46 | register long count;
|
---|
47 | register int c;
|
---|
48 |
|
---|
49 | for (count = 0; count < len; count++) {
|
---|
50 |
|
---|
51 | if (EOF EQ (c = getc(fp))) {
|
---|
52 |
|
---|
53 | printf("ERROR: Unexpected EOF -- errno = %d\n", errno);
|
---|
54 | fclose(fp);
|
---|
55 | return(FAILURE);
|
---|
56 |
|
---|
57 | } else {
|
---|
58 |
|
---|
59 | *to++ = c;
|
---|
60 | }
|
---|
61 | }
|
---|
62 |
|
---|
63 | return(SUCCESS);
|
---|
64 | }
|
---|
65 |
|
---|
66 | /*
|
---|
67 | =============================================================================
|
---|
68 | die() -- close a file and terminate the program
|
---|
69 | =============================================================================
|
---|
70 | */
|
---|
71 |
|
---|
72 | die(fp)
|
---|
73 | FILE *fp;
|
---|
74 | {
|
---|
75 | fclose(fp);
|
---|
76 | printf("Program terminated\n");
|
---|
77 | exit(1);
|
---|
78 | }
|
---|
79 |
|
---|
80 | /* |
---|
81 |
|
---|
82 | */
|
---|
83 |
|
---|
84 | /*
|
---|
85 | =============================================================================
|
---|
86 | convert an instrument definition to a data block in a header file
|
---|
87 | =============================================================================
|
---|
88 | */
|
---|
89 |
|
---|
90 | main()
|
---|
91 | {
|
---|
92 | register FILE *fp;
|
---|
93 | register unsigned *wp;
|
---|
94 | register struct instdef *ip;
|
---|
95 | register short i, npl, count;
|
---|
96 |
|
---|
97 | if ((FILE *)NULL EQ (fp = fopenb(LIBNAME, "r"))) {
|
---|
98 |
|
---|
99 | printf("Unable to open [%s]\n", LIBNAME);
|
---|
100 | exit(1);
|
---|
101 | }
|
---|
102 |
|
---|
103 | printf("Reading orchestra from [%s]\n", LIBNAME);
|
---|
104 |
|
---|
105 | printf(" header\n");
|
---|
106 |
|
---|
107 | if (readit(fp, &ldhead, (long)LH_LEN))
|
---|
108 | die(fp);
|
---|
109 |
|
---|
110 | for (i = 0; i < NINORC; i++) {
|
---|
111 |
|
---|
112 | ip = &idefs[i];
|
---|
113 |
|
---|
114 | printf(" instrument %d\n", i + 1);
|
---|
115 |
|
---|
116 | if (readit(fp, ip, (long)OR_LEN1))
|
---|
117 | die(fp);
|
---|
118 |
|
---|
119 | if (readit(fp, ip->idhwvao, (long)OR_LEN2))
|
---|
120 | die(fp);
|
---|
121 |
|
---|
122 | if (readit(fp, ip->idhwvbo, (long)OR_LEN2))
|
---|
123 | die(fp);
|
---|
124 |
|
---|
125 | /* unpack offsets (and eventually harmonics) into finals */
|
---|
126 |
|
---|
127 | memcpyw(ip->idhwvaf, ip->idhwvao, NUMWPNT);
|
---|
128 | memcpyw(ip->idhwvbf, ip->idhwvbo, NUMWPNT);
|
---|
129 | }
|
---|
130 |
|
---|
131 | fclose(fp);
|
---|
132 | /* |
---|
133 |
|
---|
134 | */
|
---|
135 | if ((FILE *)NULL EQ (fp = fopena(DFLTNAME, "w"))) {
|
---|
136 |
|
---|
137 | printf("Unable to open [%s] for output\n", DFLTNAME);
|
---|
138 | exit(1);
|
---|
139 | }
|
---|
140 |
|
---|
141 | printf("Writing default instrument (%d) to [%s]\n",
|
---|
142 | (THEINST + 1), DFLTNAME);
|
---|
143 |
|
---|
144 | count = sizeof (struct instdef) / 2;
|
---|
145 | wp = (unsigned *)&idefs[THEINST];
|
---|
146 | npl = 0;
|
---|
147 |
|
---|
148 | fprintf(fp, "short\tdfltins[] = {\t\t/* default instrument */\n\n\t");
|
---|
149 |
|
---|
150 | while (count--) {
|
---|
151 |
|
---|
152 | fprintf(fp, "0x%04.4x", *wp++);
|
---|
153 |
|
---|
154 | if (++npl EQ MAXPERL) {
|
---|
155 |
|
---|
156 | if (count)
|
---|
157 | fprintf(fp, ",\n\t");
|
---|
158 |
|
---|
159 | npl = 0;
|
---|
160 |
|
---|
161 | } else {
|
---|
162 |
|
---|
163 | if (count)
|
---|
164 | fprintf(fp, ", ");
|
---|
165 | }
|
---|
166 | }
|
---|
167 |
|
---|
168 | fprintf(fp, "\n};\n");
|
---|
169 | fclose(fp);
|
---|
170 | printf("Default instrument file written.\n");
|
---|
171 | exit(0);
|
---|
172 | }
|
---|