bankfile.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
112
113
114
115
116
117
//====================================================================
// bankfile.c++
//
// Synopsis:
//
// Author(s)
// Steve Shepard
//
// 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 <stdlib.h>
#include "libbank.h"
ICBankFile *curBankFile = 0;
ICBankFile::ICBankFile()
{
declclass = ICBANKFILE;
size = sizeof(ALBankFile) - sizeof(ALBank *); /* size in file */
bankCount = 0;
bankfile = 0;
}
void ICBankFile::AddBank(ICBank *b, int /*number*/)
{
FailIf(b->GetObjectClass() != ICBANK, IC_TYPE_ERR);
bankList.Append(b);
size += sizeof(ALBank *);
bankCount++;
}
ICBank* ICBankFile::GetBank(int number)
{
Node *node;
int count=0;
for (node = bankList.head; node != 0; node = node->next){
if(count == number)
return((ICBank *)node->data);
count++;
}
return 0;
}
void ICBankFile::Assemble()
{
Node *obj;
int j=0;
size = Size();
FailIfMsg(!bankCount, IC_INTERNAL_ERR, "no banks in bankfile");
ALBankFile *b = (ALBankFile *)calloc(1, size);
FailIf(!b, IC_INTERNAL_ERR);
b->revision = AL_BANK_VERSION;
b->bankCount = bankCount;
for (obj = bankList.head; obj != 0; obj = obj->next) {
ICBank *decl = (ICBank *)obj->data;
b->bankArray[j++] = (ALBank *)decl->GetObjectOffset();
}
bankfile = b;
thing = bankfile;
}
void ICBankFile::Prune()
{
Node *node;
this->IncRefCount();
for (node = bankList.head; node != 0; node = node->next){
((ICBank *)node->data)->Prune();
}
}
void ICBankFile::Print()
{
int i;
if (declid)
printf("BankFile: %s\n", declid->name);
else
printf("BankFile: \n");
ICObject::Print();
FailIf(!bankfile, IC_INTERNAL_ERR);
printf("\tbankCount:\t= %d\n", bankfile->bankCount);
for (i = 0; i < bankfile->bankCount; i++) {
printf("\tbank[%d]\t\t= %x\n", i, bankfile->bankArray[i]);
}
printf("\n");
}