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
|
package com.pkrandom.pokemon;
/*----------------------------------------------------------------------------*/
/*-- ItemList.java - contains the list of all items in the game. --*/
/*-- --*/
/*-- Part of "Universal Pokemon Randomizer ZX" by the UPR-ZX team --*/
/*-- Pokemon and any associated names and the like are --*/
/*-- trademark and (C) Nintendo 1996-2020. --*/
/*-- --*/
/*-- The custom code written here is licensed under the terms of the GPL: --*/
/*-- --*/
/*-- This program 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. --*/
/*-- --*/
/*-- This program 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 this program. If not, see <http://www.gnu.org/licenses/>. --*/
/*----------------------------------------------------------------------------*/
import java.util.Random;
public class ItemList {
private boolean[] items;
private boolean[] tms;
public ItemList(int highestIndex) {
items = new boolean[highestIndex + 1];
tms = new boolean[highestIndex + 1];
for (int i = 1; i <= highestIndex; i++) {
items[i] = true;
}
}
public boolean isTM(int index) {
return index >= 0 && index < tms.length && tms[index];
}
public boolean isAllowed(int index) {
return index >= 0 && index < tms.length && items[index];
}
public void banSingles(int... indexes) {
for (int index : indexes) {
items[index] = false;
}
}
public void banRange(int startIndex, int length) {
for (int i = 0; i < length; i++) {
items[i + startIndex] = false;
}
}
public void tmRange(int startIndex, int length) {
for (int i = 0; i < length; i++) {
tms[i + startIndex] = true;
}
}
public int randomItem(Random random) {
int chosen = 0;
while (!items[chosen]) {
chosen = random.nextInt(items.length);
}
return chosen;
}
public int randomNonTM(Random random) {
int chosen = 0;
while (!items[chosen] || tms[chosen]) {
chosen = random.nextInt(items.length);
}
return chosen;
}
public int randomTM(Random random) {
int chosen = 0;
while (!tms[chosen]) {
chosen = random.nextInt(items.length);
}
return chosen;
}
public ItemList copy() {
ItemList other = new ItemList(items.length - 1);
System.arraycopy(items, 0, other.items, 0, items.length);
System.arraycopy(tms, 0, other.tms, 0, tms.length);
return other;
}
public ItemList copy(int newMax) {
ItemList other = new ItemList(newMax);
System.arraycopy(items, 0, other.items, 0, items.length);
System.arraycopy(tms, 0, other.tms, 0, tms.length);
return other;
}
}
|