This repository was archived by the owner on Jul 23, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 11
Expand file tree
/
Copy pathcMultiWireWalker.cpp
More file actions
74 lines (66 loc) · 1.9 KB
/
cMultiWireWalker.cpp
File metadata and controls
74 lines (66 loc) · 1.9 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
/******************************************************************************
Copyright 2012 Victor Yurkovsky
This file is part of FPGAsm
FPGAsm is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
FPGAsm is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with FPGAsm. If not, see <http://www.gnu.org/licenses/>.
******************************************************************************/
#include "global.h"
#include "cMultiWireWalker.h"
#define CLASS cMultiWireWalker
CLASS::CLASS(cMultiWire& it){
buf=it.getBuf();
index=0;
}
CLASS::~CLASS(){
buf=0;
//do not free - we don't own the wire, just walk it
}
void CLASS::getInc(int& inst,int& pindex,int& busid){
inst = buf[index].inst;
pindex = buf[index].pindex;
busid = buf[index].busid;
index++;
}
sWireEnd& CLASS::getInc(){
return buf[index++];
}
bool CLASS::isStop(void){
return(INST_STOP==buf[index].inst);
}
bool CLASS::isEnd(void){
return(INST_END==buf[index].inst);
}
// Seek next wire. If end, leave at end.
bool CLASS::seekNext(){
while(true){
switch(buf[index].inst){
case INST_STOP:
index++;
return true;
case INST_END:
return false;
default:
index++;
break;
}
}
}
//seek a particular instance
bool CLASS::seekInst(int inst){
if(isEnd())
return false; //at end!
//starting at outgoing instance pointer...
while(seekNext()){
if(inst==buf[index].inst)
return true;
}
return false;
}