envelope.c
2.75 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*====================================================================
* envelope.c
*
* Copyright 1993, Silicon Graphics, Inc.
* All Rights Reserved.
*
* This is UNPUBLISHED PROPRIETARY SOURCE CODE of Silicon Graphics,
* Inc.; the contents of this file may not be disclosed to third
* parties, copied or duplicated in any form, in whole or in part,
* without the prior written permission of Silicon Graphics, Inc.
*
* RESTRICTED RIGHTS LEGEND:
* Use, duplication or disclosure by the Government is subject to
* restrictions as set forth in subdivision (c)(1)(ii) of the Rights
* in Technical Data and Computer Software clause at DFARS
* 252.227-7013, and/or in similar or successor clauses in the FAR,
* DOD or NASA FAR Supplement. Unpublished - rights reserved under the
* Copyright Laws of the United States.
*====================================================================*/
#include <assert.h>
#include <stdlib.h>
#include "ic.h"
ICEnvelope *curEnvelope=0;
void envNew(ICEnvelope *env)
{
env->decl.declclass = ICENVELOPE;
env->decl.id = objectID++;
env->decl.offset = (void *)-1; /* not allocated yet */
env->decl.size = sizeof(ALEnvelope);
env->envelope = 0;
}
void envSetAttackTime(ICEnvelope *e, int t)
{
e->attackTime = t;
}
void envSetAttackVol(ICEnvelope *e, short v)
{
e->attackVol = v;
}
void envSetDecayTime(ICEnvelope *e, int t)
{
e->decayTime = t;
}
void envSetDecayVol(ICEnvelope *e, short v)
{
e->decayVol = v;
}
void envSetReleaseTime(ICEnvelope *e, int t)
{
e->releaseTime = t;
}
void envSetReleaseVol(ICEnvelope *e, short v)
{
e->releaseVol = v;
}
void envLayOut(ICEnvelope *env)
{
ALEnvelope *e;
env->decl.size = declSize((Decl *)env);
e = calloc(1, env->decl.size);
assert(e);
e->attackTime = env->attackTime;
e->attackVolume = env->attackVol;
e->decayTime = env->decayTime;
e->decayVolume = env->decayVol;
e->releaseTime = env->releaseTime;
e->releaseVolume = env->releaseVol;
env->envelope = e;
}
void envPrint(ICEnvelope *env)
{
ALEnvelope *e = env->envelope;
Id *name;
name = findname((Decl *)env);
if (name) {
printf("Envelope: %s\n", name->name);
} else {
printf("Envelope: \n");
}
declPrint((Decl *)env);
printf("\tattackTime:\t= %x\n", e->attackTime);
printf("\tattackVolume:\t= %x\n", e->attackVolume);
printf("\tdecayTime:\t= %x\n", e->decayTime);
printf("\tdecayVolume:\t= %x\n", e->decayVolume);
printf("\treleaseTime:\t= %x\n", e->releaseTime);
printf("\treleaseVolume:\t= %x\n", e->releaseVolume);
printf("\n");
}
void envWrite(ICEnvelope *env, FILE *file)
{
fwrite(env->envelope, env->decl.size, 1, file);
}