-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLatchElm.java
More file actions
39 lines (37 loc) · 1.06 KB
/
LatchElm.java
File metadata and controls
39 lines (37 loc) · 1.06 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
import java.awt.*;
import java.util.StringTokenizer;
class LatchElm extends ChipElm {
public LatchElm(int xx, int yy) { super(xx, yy); }
public LatchElm(int xa, int ya, int xb, int yb, int f,
StringTokenizer st) {
super(xa, ya, xb, yb, f, st);
}
String getChipName() { return "Latch"; }
boolean needsBits() { return true; }
int loadPin;
void setupPins() {
sizeX = 2;
sizeY = bits+1;
pins = new Pin[getPostCount()];
int i;
for (i = 0; i != bits; i++)
pins[i] = new Pin(bits-1-i, SIDE_W, "I" + i);
for (i = 0; i != bits; i++) {
pins[i+bits] = new Pin(bits-1-i, SIDE_E, "O");
pins[i+bits].output = true;
}
pins[loadPin = bits*2] = new Pin(bits, SIDE_W, "Ld");
allocNodes();
}
boolean lastLoad = false;
void execute() {
int i;
if (pins[loadPin].value && !lastLoad)
for (i = 0; i != bits; i++)
pins[i+bits].value = pins[i].value;
lastLoad = pins[loadPin].value;
}
int getVoltageSourceCount() { return bits; }
int getPostCount() { return bits*2+1; }
int getDumpType() { return 168; }
}