picrate 1.3.0-java → 2.0.0.pre-java

Sign up to get free protection for your applications and to get access to all the features.
Files changed (81) hide show
  1. checksums.yaml +4 -4
  2. data/.mvn/extensions.xml +1 -1
  3. data/.mvn/wrapper/maven-wrapper.properties +2 -2
  4. data/CHANGELOG.md +2 -1
  5. data/Gemfile +3 -1
  6. data/README.md +4 -2
  7. data/Rakefile +8 -4
  8. data/bin/picrate +3 -1
  9. data/docs/_posts/2019-11-11-getting_started_buster.md +1 -1
  10. data/lib/picrate.rb +1 -1
  11. data/lib/picrate/app.rb +10 -3
  12. data/lib/picrate/creators/parameters.rb +8 -8
  13. data/lib/picrate/creators/sketch_factory.rb +5 -3
  14. data/lib/picrate/helper_methods.rb +21 -21
  15. data/lib/picrate/helpers/numeric.rb +2 -0
  16. data/lib/picrate/library.rb +5 -1
  17. data/lib/picrate/library_loader.rb +2 -0
  18. data/lib/picrate/native_folder.rb +6 -4
  19. data/lib/picrate/native_loader.rb +3 -0
  20. data/lib/picrate/runner.rb +1 -0
  21. data/lib/picrate/version.rb +1 -1
  22. data/library/boids/boids.rb +17 -8
  23. data/library/chooser/chooser.rb +10 -9
  24. data/library/color_group/color_group.rb +2 -0
  25. data/library/control_panel/control_panel.rb +7 -4
  26. data/library/dxf/dxf.rb +2 -0
  27. data/library/library_proxy/library_proxy.rb +2 -0
  28. data/library/net/net.rb +2 -0
  29. data/library/slider/slider.rb +24 -23
  30. data/library/vector_utils/vector_utils.rb +4 -0
  31. data/library/video_event/video_event.rb +2 -0
  32. data/picrate.gemspec +14 -12
  33. data/pom.rb +15 -15
  34. data/pom.xml +5 -5
  35. data/src/main/java/monkstone/ColorUtil.java +1 -1
  36. data/src/main/java/monkstone/MathToolModule.java +1 -1
  37. data/src/main/java/monkstone/PicrateLibrary.java +8 -8
  38. data/src/main/java/monkstone/fastmath/Deglut.java +16 -16
  39. data/src/main/java/monkstone/filechooser/Chooser.java +1 -1
  40. data/src/main/java/monkstone/noise/SimplexNoise.java +3 -3
  41. data/src/main/java/monkstone/slider/CustomHorizontalSlider.java +1 -1
  42. data/src/main/java/monkstone/slider/CustomVerticalSlider.java +1 -1
  43. data/src/main/java/monkstone/slider/SimpleHorizontalSlider.java +12 -12
  44. data/src/main/java/monkstone/slider/SimpleVerticalSlider.java +1 -1
  45. data/src/main/java/monkstone/slider/SliderBar.java +1 -1
  46. data/src/main/java/monkstone/slider/SliderGroup.java +1 -1
  47. data/src/main/java/monkstone/slider/WheelHandler.java +1 -1
  48. data/src/main/java/monkstone/vecmath/package-info.java +1 -1
  49. data/src/main/java/monkstone/vecmath/vec2/Vec2.java +1 -1
  50. data/src/main/java/monkstone/vecmath/vec3/Vec3.java +1 -1
  51. data/src/main/java/monkstone/videoevent/CaptureEvent.java +1 -1
  52. data/src/main/java/monkstone/videoevent/MovieEvent.java +1 -1
  53. data/src/main/java/monkstone/videoevent/package-info.java +1 -1
  54. data/src/main/java/processing/awt/PGraphicsJava2D.java +11 -13
  55. data/src/main/java/processing/awt/PSurfaceAWT.java +0 -20
  56. data/src/main/java/processing/core/PApplet.java +1949 -2247
  57. data/src/main/java/processing/core/PConstants.java +180 -180
  58. data/src/main/java/processing/core/PFont.java +2 -2
  59. data/src/main/java/processing/core/PGraphics.java +90 -90
  60. data/src/main/java/processing/core/PImage.java +65 -65
  61. data/src/main/java/processing/core/PMatrix.java +39 -39
  62. data/src/main/java/processing/core/PSurface.java +37 -37
  63. data/src/main/java/processing/core/PVector.java +2 -2
  64. data/src/main/java/processing/data/FloatDict.java +251 -284
  65. data/src/main/java/processing/data/TableRow.java +32 -32
  66. data/src/main/java/processing/dxf/RawDXF.java +3 -3
  67. data/src/main/java/processing/net/Client.java +1 -1
  68. data/src/main/java/processing/opengl/PGL.java +3884 -3950
  69. data/src/main/java/processing/opengl/PGraphicsOpenGL.java +38 -21
  70. data/src/main/java/processing/opengl/PSurfaceJOGL.java +42 -61
  71. data/test/color_group_test.rb +4 -4
  72. data/test/deglut_spec_test.rb +2 -0
  73. data/test/helper_methods_test.rb +41 -13
  74. data/test/math_tool_test.rb +46 -37
  75. data/test/respond_to_test.rb +5 -3
  76. data/test/sketches/key_event.rb +2 -2
  77. data/test/sketches/library/my_library/my_library.rb +3 -0
  78. data/test/test_helper.rb +2 -0
  79. data/test/vecmath_spec_test.rb +30 -19
  80. data/vendors/Rakefile +2 -2
  81. metadata +29 -17
@@ -30,31 +30,31 @@ public interface PSurface {
30
30
  /**
31
31
  * Minimum dimensions for the window holding an applet.
32
32
  */
33
- static public final int MIN_WINDOW_WIDTH = 128;
33
+ int MIN_WINDOW_WIDTH = 128;
34
34
 
35
35
  /**
36
36
  *
37
37
  */
38
- static public final int MIN_WINDOW_HEIGHT = 128;
38
+ int MIN_WINDOW_HEIGHT = 128;
39
39
 
40
40
  // renderer that doesn't draw to the screen
41
41
  /**
42
42
  *
43
43
  * @param sketch
44
44
  */
45
- public void initOffscreen(PApplet sketch);
45
+ void initOffscreen(PApplet sketch);
46
46
 
47
47
  // considering removal in favor of separate Component classes for appropriate renderers
48
48
  // (i.e. for Java2D or a generic Image surface, but not PDF, debatable for GL or FX)
49
- //public Component initComponent(PApplet sketch);
50
- //public Frame initFrame(PApplet sketch, Color backgroundColor,
51
- // public void initFrame(PApplet sketch, int backgroundColor,
49
+ //Component initComponent(PApplet sketch);
50
+ //Frame initFrame(PApplet sketch, Color backgroundColor,
51
+ // void initFrame(PApplet sketch, int backgroundColor,
52
52
  // int deviceIndex, boolean fullScreen, boolean spanDisplays);
53
53
  /**
54
54
  *
55
55
  * @param sketch
56
56
  */
57
- public void initFrame(PApplet sketch);
57
+ void initFrame(PApplet sketch);
58
58
 
59
59
  /**
60
60
  * Get the native window object associated with this drawing surface. For
@@ -66,7 +66,7 @@ public interface PSurface {
66
66
  *
67
67
  * @return
68
68
  */
69
- public Object getNative();
69
+ Object getNative();
70
70
 
71
71
  //
72
72
  // Just call these on an AWT Frame object stored in PApplet.
@@ -77,73 +77,73 @@ public interface PSurface {
77
77
  *
78
78
  * @param title
79
79
  */
80
- public void setTitle(String title);
80
+ void setTitle(String title);
81
81
 
82
82
  /**
83
83
  * Show or hide the window.
84
84
  *
85
85
  * @param visible
86
86
  */
87
- public void setVisible(boolean visible);
87
+ void setVisible(boolean visible);
88
88
 
89
89
  /**
90
90
  * Set true if we want to resize things (default is not resizable)
91
91
  *
92
92
  * @param resizable
93
93
  */
94
- public void setResizable(boolean resizable);
94
+ void setResizable(boolean resizable);
95
95
 
96
96
  /**
97
97
  * Dumb name, but inherited from Frame and no better ideas.
98
98
  *
99
99
  * @param always
100
100
  */
101
- public void setAlwaysOnTop(boolean always);
101
+ void setAlwaysOnTop(boolean always);
102
102
 
103
103
  /**
104
104
  *
105
105
  * @param icon
106
106
  */
107
- public void setIcon(PImage icon);
107
+ void setIcon(PImage icon);
108
108
 
109
109
  //
110
- // public void placeWindow(int[] location);
110
+ // void placeWindow(int[] location);
111
111
  /**
112
112
  *
113
113
  * @param location
114
114
  * @param editorLocation
115
115
  */
116
- public void placeWindow(int[] location, int[] editorLocation);
116
+ void placeWindow(int[] location, int[] editorLocation);
117
117
 
118
- //public void placeFullScreen(boolean hideStop);
118
+ //void placeFullScreen(boolean hideStop);
119
119
  /**
120
120
  *
121
121
  * @param stopColor
122
122
  */
123
- public void placePresent(int stopColor);
123
+ void placePresent(int stopColor);
124
124
 
125
125
  // Sketch is running from the PDE, set up messaging back to the PDE
126
126
  /**
127
127
  *
128
128
  */
129
- public void setupExternalMessages();
129
+ void setupExternalMessages();
130
130
 
131
131
  //
132
132
  // sets displayWidth/Height inside PApplet
133
- //public void checkDisplaySize();
133
+ //void checkDisplaySize();
134
134
  /**
135
135
  *
136
136
  * @param x
137
137
  * @param y
138
138
  */
139
- public void setLocation(int x, int y);
139
+ void setLocation(int x, int y);
140
140
 
141
141
  /**
142
142
  *
143
143
  * @param width
144
144
  * @param height
145
145
  */
146
- public void setSize(int width, int height);
146
+ void setSize(int width, int height);
147
147
 
148
148
  // /**
149
149
  // * Called by {@link PApplet#createGraphics} to initialize the
@@ -154,32 +154,32 @@ public interface PSurface {
154
154
  // * @param high
155
155
  // */
156
156
  // create pixel buffer (pulled out for offscreen graphics)
157
- //public void initImage(PGraphics gr, int wide, int high);
157
+ //void initImage(PGraphics gr, int wide, int high);
158
158
  // create pixel buffer, called from allocate() to produce a compatible image for rendering efficiently
159
- // public void initImage(PGraphics gr);
160
- //public Component getComponent();
159
+ // void initImage(PGraphics gr);
160
+ //Component getComponent();
161
161
  // /**
162
162
  // * Sometimes smoothing must be set at the drawing surface level
163
163
  // * not just inside the renderer itself.
164
164
  // */
165
- // public void setSmooth(int level);
165
+ // void setSmooth(int level);
166
166
  /**
167
167
  *
168
168
  * @param fps
169
169
  */
170
- public void setFrameRate(float fps);
170
+ void setFrameRate(float fps);
171
171
 
172
172
  // // called on the first frame so that the now-visible drawing surface can
173
173
  // // receive key and mouse events
174
- // public void requestFocus();
174
+ // void requestFocus();
175
175
  // // finish rendering to the screen (called by PApplet)
176
- // public void blit();
176
+ // void blit();
177
177
  //
178
178
  /**
179
179
  *
180
180
  * @param kind
181
181
  */
182
- public void setCursor(int kind);
182
+ void setCursor(int kind);
183
183
 
184
184
  /**
185
185
  *
@@ -187,46 +187,46 @@ public interface PSurface {
187
187
  * @param hotspotX
188
188
  * @param hotspotY
189
189
  */
190
- public void setCursor(PImage image, int hotspotX, int hotspotY);
190
+ void setCursor(PImage image, int hotspotX, int hotspotY);
191
191
 
192
192
  /**
193
193
  *
194
194
  */
195
- public void showCursor();
195
+ void showCursor();
196
196
 
197
197
  /**
198
198
  *
199
199
  */
200
- public void hideCursor();
200
+ void hideCursor();
201
201
 
202
202
  //
203
203
  /**
204
204
  * Start the animation thread
205
205
  */
206
- public void startThread();
206
+ void startThread();
207
207
 
208
208
  /**
209
209
  * On the next trip through the animation thread, things should go sleepy-bye.
210
210
  * Does not pause the thread immediately because that needs to happen on the
211
211
  * animation thread itself, so fires on the next trip through draw().
212
212
  */
213
- public void pauseThread();
213
+ void pauseThread();
214
214
 
215
215
  /**
216
216
  *
217
217
  */
218
- public void resumeThread();
218
+ void resumeThread();
219
219
 
220
220
  /**
221
221
  * Stop the animation thread (set it null)
222
222
  *
223
223
  * @return false if already stopped
224
224
  */
225
- public boolean stopThread();
225
+ boolean stopThread();
226
226
 
227
227
  /**
228
228
  *
229
229
  * @return
230
230
  */
231
- public boolean isStopped();
231
+ boolean isStopped();
232
232
  }
@@ -45,8 +45,8 @@ import processing.core.PConstants;
45
45
  * represent groupings of values, we cannot simply use traditional
46
46
  * addition/multiplication/etc. Instead, we'll need to do some "vector"
47
47
  * math, which is made easy by the methods inside the <b>PVector</b>
48
- * class.<br />
49
- * <br />
48
+ * class.
49
+ *
50
50
  * The methods for this class are extensive. For a complete list, visit the
51
51
  * <a
52
52
  * href="http://processing.googlecode.com/svn/trunk/processing/build/javadoc/core/">developer's reference.</a>
@@ -1,12 +1,12 @@
1
1
  package processing.data;
2
2
 
3
- import java.io.*;
3
+ import java.io.BufferedReader;
4
+ import java.io.PrintWriter;
4
5
  import java.util.HashMap;
5
6
  import java.util.Iterator;
6
7
 
7
8
  import processing.core.PApplet;
8
9
 
9
-
10
10
  /**
11
11
  * A simple table class to use a String as a lookup for an float value.
12
12
  *
@@ -16,37 +16,41 @@ import processing.core.PApplet;
16
16
  */
17
17
  public class FloatDict {
18
18
 
19
- /** Number of elements in the table */
19
+ /**
20
+ * Number of elements in the table
21
+ */
20
22
  protected int count;
21
23
 
22
- /**
23
- *
24
- */
25
- protected String[] keys;
24
+ /**
25
+ *
26
+ */
27
+ protected String[] keys;
26
28
 
27
- /**
28
- *
29
- */
30
- protected float[] values;
29
+ /**
30
+ *
31
+ */
32
+ protected float[] values;
31
33
 
32
- /** Internal implementation for faster lookups */
34
+ /**
35
+ * Internal implementation for faster lookups
36
+ */
33
37
  private HashMap<String, Integer> indices = new HashMap<>();
34
38
 
35
- /**
36
- *
37
- */
38
- public FloatDict() {
39
+ /**
40
+ *
41
+ */
42
+ public FloatDict() {
39
43
  count = 0;
40
44
  keys = new String[10];
41
45
  values = new float[10];
42
46
  }
43
47
 
44
-
45
48
  /**
46
49
  * Create a new lookup with a specific size.This is more efficient than not
47
- specifying a size. Use it when you know the rough size of the thing you're creating.
50
+ * specifying a size. Use it when you know the rough size of the thing you're
51
+ * creating.
48
52
  *
49
- * @param length
53
+ * @param length
50
54
  * @nowebref
51
55
  */
52
56
  public FloatDict(int length) {
@@ -55,12 +59,11 @@ public class FloatDict {
55
59
  values = new float[length];
56
60
  }
57
61
 
58
-
59
62
  /**
60
- * Read a set of entries from a Reader that has each key/value pair on
61
- * a single line, separated by a tab.
63
+ * Read a set of entries from a Reader that has each key/value pair on a
64
+ * single line, separated by a tab.
62
65
  *
63
- * @param reader
66
+ * @param reader
64
67
  * @nowebref
65
68
  */
66
69
  public FloatDict(BufferedReader reader) {
@@ -68,8 +71,8 @@ public class FloatDict {
68
71
  keys = new String[lines.length];
69
72
  values = new float[lines.length];
70
73
 
71
- for (int i = 0; i < lines.length; i++) {
72
- String[] pieces = PApplet.split(lines[i], '\t');
74
+ for (String line : lines) {
75
+ String[] pieces = PApplet.split(line, '\t');
73
76
  if (pieces.length == 2) {
74
77
  keys[count] = pieces[0];
75
78
  values[count] = PApplet.parseFloat(pieces[1]);
@@ -79,10 +82,9 @@ public class FloatDict {
79
82
  }
80
83
  }
81
84
 
82
-
83
85
  /**
84
- * @param keys
85
- * @param values
86
+ * @param keys
87
+ * @param values
86
88
  * @nowebref
87
89
  */
88
90
  public FloatDict(String[] keys, float[] values) {
@@ -97,7 +99,6 @@ public class FloatDict {
97
99
  }
98
100
  }
99
101
 
100
-
101
102
  /**
102
103
  * Constructor to allow (more intuitive) inline initialization, e.g.:
103
104
  * <pre>
@@ -106,7 +107,8 @@ public class FloatDict {
106
107
  * { "key2", 2 }
107
108
  * });
108
109
  * </pre>
109
- * @param pairs
110
+ *
111
+ * @param pairs
110
112
  */
111
113
  public FloatDict(Object[][] pairs) {
112
114
  count = pairs.length;
@@ -119,23 +121,24 @@ public class FloatDict {
119
121
  }
120
122
  }
121
123
 
122
-
123
124
  /**
124
- * @return
125
- * @webref floatdict:method
125
+ * @return @webref floatdict:method
126
126
  * @brief Returns the number of key/value pairs
127
127
  */
128
128
  public int size() {
129
129
  return count;
130
130
  }
131
131
 
132
-
133
132
  /**
134
- * Resize the internal data, this can only be used to shrink the list.Helpful for situations like sorting and then grabbing the top 50 entries.
135
- * @param arg0
133
+ * Resize the internal data, this can only be used to shrink the list.Helpful
134
+ * for situations like sorting and then grabbing the top 50 entries.
135
+ *
136
+ * @param length
136
137
  */
137
138
  public void resize(int length) {
138
- if (length == count) return;
139
+ if (length == count) {
140
+ return;
141
+ }
139
142
 
140
143
  if (length > count) {
141
144
  throw new IllegalArgumentException("resize() can only be used to shrink the dictionary");
@@ -154,7 +157,6 @@ public class FloatDict {
154
157
  resetIndices();
155
158
  }
156
159
 
157
-
158
160
  /**
159
161
  * Remove all entries.
160
162
  *
@@ -166,7 +168,6 @@ public class FloatDict {
166
168
  indices = new HashMap<>();
167
169
  }
168
170
 
169
-
170
171
  private void resetIndices() {
171
172
  indices = new HashMap<>(count);
172
173
  for (int i = 0; i < count; i++) {
@@ -174,25 +175,21 @@ public class FloatDict {
174
175
  }
175
176
  }
176
177
 
177
-
178
178
  // . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
179
+ /**
180
+ *
181
+ */
182
+ public class Entry {
179
183
 
180
184
  /**
181
185
  *
182
186
  */
187
+ public String key;
183
188
 
184
-
185
- public class Entry {
186
-
187
- /**
188
- *
189
- */
190
- public String key;
191
-
192
- /**
193
- *
194
- */
195
- public float value;
189
+ /**
190
+ *
191
+ */
192
+ public float value;
196
193
 
197
194
  Entry(String key, float value) {
198
195
  this.key = key;
@@ -200,113 +197,101 @@ public class FloatDict {
200
197
  }
201
198
  }
202
199
 
203
- /**
204
- *
205
- * @return
206
- */
207
- public Iterable<Entry> entries() {
208
- return new Iterable<Entry>() {
209
-
210
- public Iterator<Entry> iterator() {
211
- return entryIterator();
212
- }
213
- };
200
+ /**
201
+ *
202
+ * @return
203
+ */
204
+ public Iterable<Entry> entries() {
205
+ return () -> entryIterator();
214
206
  }
215
207
 
216
- /**
217
- *
218
- * @return
219
- */
220
- public Iterator<Entry> entryIterator() {
208
+ /**
209
+ *
210
+ * @return
211
+ */
212
+ public Iterator<Entry> entryIterator() {
221
213
  return new Iterator<Entry>() {
222
214
  int index = -1;
223
215
 
216
+ @Override
224
217
  public void remove() {
225
218
  removeIndex(index);
226
219
  index--;
227
220
  }
228
221
 
222
+ @Override
229
223
  public Entry next() {
230
224
  ++index;
231
225
  Entry e = new Entry(keys[index], values[index]);
232
226
  return e;
233
227
  }
234
228
 
229
+ @Override
235
230
  public boolean hasNext() {
236
- return index+1 < size();
231
+ return index + 1 < size();
237
232
  }
238
233
  };
239
234
  }
240
235
 
241
-
242
236
  // . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
243
-
244
- /**
245
- *
246
- * @param index
247
- * @return
248
- */
249
-
250
-
237
+ /**
238
+ *
239
+ * @param index
240
+ * @return
241
+ */
251
242
  public String key(int index) {
252
243
  return keys[index];
253
244
  }
254
245
 
255
- /**
256
- *
257
- */
258
- protected void crop() {
246
+ /**
247
+ *
248
+ */
249
+ protected void crop() {
259
250
  if (count != keys.length) {
260
251
  keys = PApplet.subset(keys, 0, count);
261
252
  values = PApplet.subset(values, 0, count);
262
253
  }
263
254
  }
264
255
 
265
- /**
266
- *
267
- * @return
268
- */
269
- public Iterable<String> keys() {
270
- return new Iterable<String>() {
271
-
272
- @Override
273
- public Iterator<String> iterator() {
274
- return keyIterator();
275
- }
276
- };
256
+ /**
257
+ *
258
+ * @return
259
+ */
260
+ public Iterable<String> keys() {
261
+ return () -> keyIterator();
277
262
  }
278
263
 
279
-
280
264
  // Use this to iterate when you want to be able to remove elements along the way
281
-
282
- /**
283
- *
284
- * @return
285
- */
265
+ /**
266
+ *
267
+ * @return
268
+ */
286
269
  public Iterator<String> keyIterator() {
287
270
  return new Iterator<String>() {
288
271
  int index = -1;
289
272
 
273
+ @Override
290
274
  public void remove() {
291
275
  removeIndex(index);
292
276
  index--;
293
277
  }
294
278
 
279
+ @Override
295
280
  public String next() {
296
281
  return key(++index);
297
282
  }
298
283
 
284
+ @Override
299
285
  public boolean hasNext() {
300
- return index+1 < size();
286
+ return index + 1 < size();
301
287
  }
302
288
  };
303
289
  }
304
290
 
305
-
306
291
  /**
307
292
  * Return a copy of the internal keys array.This array can be modified.
308
293
  *
309
- * @return
294
+ * @return
310
295
  * @webref floatdict:method
311
296
  * @brief Return a copy of the internal keys array
312
297
  */
@@ -315,12 +300,12 @@ public class FloatDict {
315
300
  return keyArray(null);
316
301
  }
317
302
 
318
- /**
319
- *
320
- * @param outgoing
321
- * @return
322
- */
323
- public String[] keyArray(String[] outgoing) {
303
+ /**
304
+ *
305
+ * @param outgoing
306
+ * @return
307
+ */
308
+ public String[] keyArray(String[] outgoing) {
324
309
  if (outgoing == null || outgoing.length != count) {
325
310
  outgoing = new String[count];
326
311
  }
@@ -328,59 +313,53 @@ public class FloatDict {
328
313
  return outgoing;
329
314
  }
330
315
 
331
- /**
332
- *
333
- * @param index
334
- * @return
335
- */
336
- public float value(int index) {
316
+ /**
317
+ *
318
+ * @param index
319
+ * @return
320
+ */
321
+ public float value(int index) {
337
322
  return values[index];
338
323
  }
339
324
 
340
-
341
325
  /**
342
- * @return
343
- * @webref floatdict:method
326
+ * @return @webref floatdict:method
344
327
  * @brief Return the internal array being used to store the values
345
328
  */
346
329
  public Iterable<Float> values() {
347
- return new Iterable<Float>() {
348
-
349
- @Override
350
- public Iterator<Float> iterator() {
351
- return valueIterator();
352
- }
353
- };
330
+ return () -> valueIterator();
354
331
  }
355
332
 
356
- /**
357
- *
358
- * @return
359
- */
360
- public Iterator<Float> valueIterator() {
333
+ /**
334
+ *
335
+ * @return
336
+ */
337
+ public Iterator<Float> valueIterator() {
361
338
  return new Iterator<Float>() {
362
339
  int index = -1;
363
340
 
341
+ @Override
364
342
  public void remove() {
365
343
  removeIndex(index);
366
344
  index--;
367
345
  }
368
346
 
347
+ @Override
369
348
  public Float next() {
370
349
  return value(++index);
371
350
  }
372
351
 
352
+ @Override
373
353
  public boolean hasNext() {
374
- return index+1 < size();
354
+ return index + 1 < size();
375
355
  }
376
356
  };
377
357
  }
378
358
 
379
-
380
359
  /**
381
360
  * Create a new array and copy each of the values into it.
382
361
  *
383
- * @return
362
+ * @return
384
363
  * @webref floatdict:method
385
364
  * @brief Create a new array and copy each of the values into it
386
365
  */
@@ -389,13 +368,13 @@ public class FloatDict {
389
368
  return valueArray(null);
390
369
  }
391
370
 
392
-
393
371
  /**
394
372
  * Fill an already-allocated array with the values (more efficient than
395
- * creating a new array each time).If 'array' is null, or not the same
396
- size as the number of values, a new array will be allocated and returned.
397
- * @param array
398
- * @return
373
+ * creating a new array each time).If 'array' is null, or not the same size as
374
+ * the number of values, a new array will be allocated and returned.
375
+ *
376
+ * @param array
377
+ * @return
399
378
  */
400
379
  public float[] valueArray(float[] array) {
401
380
  if (array == null || array.length != size()) {
@@ -405,12 +384,11 @@ public class FloatDict {
405
384
  return array;
406
385
  }
407
386
 
408
-
409
387
  /**
410
388
  * Return a value for the specified key.
411
389
  *
412
- * @param key
413
- * @return
390
+ * @param key
391
+ * @return
414
392
  * @webref floatdict:method
415
393
  * @brief Return a value for the specified key
416
394
  */
@@ -422,13 +400,13 @@ public class FloatDict {
422
400
  return values[index];
423
401
  }
424
402
 
425
- /**
426
- *
427
- * @param key
428
- * @param alternate
429
- * @return
430
- */
431
- public float get(String key, float alternate) {
403
+ /**
404
+ *
405
+ * @param key
406
+ * @param alternate
407
+ * @return
408
+ */
409
+ public float get(String key, float alternate) {
432
410
  int index = index(key);
433
411
  if (index == -1) {
434
412
  return alternate;
@@ -436,10 +414,9 @@ public class FloatDict {
436
414
  return values[index];
437
415
  }
438
416
 
439
-
440
417
  /**
441
- * @param key
442
- * @param amount
418
+ * @param key
419
+ * @param amount
443
420
  * @webref floatdict:method
444
421
  * @brief Create a new key/value pair or change the value of one
445
422
  */
@@ -452,13 +429,13 @@ public class FloatDict {
452
429
  }
453
430
  }
454
431
 
455
- /**
456
- *
457
- * @param index
458
- * @param key
459
- * @param value
460
- */
461
- public void setIndex(int index, String key, float value) {
432
+ /**
433
+ *
434
+ * @param index
435
+ * @param key
436
+ * @param value
437
+ */
438
+ public void setIndex(int index, String key, float value) {
462
439
  if (index < 0 || index >= count) {
463
440
  throw new ArrayIndexOutOfBoundsException(index);
464
441
  }
@@ -466,10 +443,9 @@ public class FloatDict {
466
443
  values[index] = value;
467
444
  }
468
445
 
469
-
470
446
  /**
471
- * @param key
472
- * @return
447
+ * @param key
448
+ * @return
473
449
  * @webref floatdict:method
474
450
  * @brief Check if a key is a part of the data structure
475
451
  */
@@ -477,10 +453,9 @@ public class FloatDict {
477
453
  return index(key) != -1;
478
454
  }
479
455
 
480
-
481
456
  /**
482
- * @param key
483
- * @param amount
457
+ * @param key
458
+ * @param amount
484
459
  * @webref floatdict:method
485
460
  * @brief Add to a value
486
461
  */
@@ -493,10 +468,9 @@ public class FloatDict {
493
468
  }
494
469
  }
495
470
 
496
-
497
471
  /**
498
- * @param key
499
- * @param amount
472
+ * @param key
473
+ * @param amount
500
474
  * @webref floatdict:method
501
475
  * @brief Subtract from a value
502
476
  */
@@ -504,10 +478,9 @@ public class FloatDict {
504
478
  add(key, -amount);
505
479
  }
506
480
 
507
-
508
481
  /**
509
- * @param key
510
- * @param amount
482
+ * @param key
483
+ * @param amount
511
484
  * @webref floatdict:method
512
485
  * @brief Multiply a value
513
486
  */
@@ -518,10 +491,9 @@ public class FloatDict {
518
491
  }
519
492
  }
520
493
 
521
-
522
494
  /**
523
- * @param key
524
- * @param amount
495
+ * @param key
496
+ * @param amount
525
497
  * @webref floatdict:method
526
498
  * @brief Divide a value
527
499
  */
@@ -532,25 +504,24 @@ public class FloatDict {
532
504
  }
533
505
  }
534
506
 
535
-
536
507
  private void checkMinMax(String functionName) {
537
508
  if (count == 0) {
538
- String msg =
539
- String.format("Cannot use %s() on an empty %s.",
540
- functionName, getClass().getSimpleName());
509
+ String msg
510
+ = String.format("Cannot use %s() on an empty %s.",
511
+ functionName, getClass().getSimpleName());
541
512
  throw new RuntimeException(msg);
542
513
  }
543
514
  }
544
515
 
545
-
546
516
  /**
547
- * @return
548
- * @webref floatlist:method
517
+ * @return @webref floatlist:method
549
518
  * @brief Return the smallest value
550
519
  */
551
520
  public int minIndex() {
552
521
  //checkMinMax("minIndex");
553
- if (count == 0) return -1;
522
+ if (count == 0) {
523
+ return -1;
524
+ }
554
525
 
555
526
  // Will still return NaN if there are 1 or more entries, and they're all NaN
556
527
  float m = Float.NaN;
@@ -562,7 +533,7 @@ public class FloatDict {
562
533
  mi = i;
563
534
 
564
535
  // calculate the rest
565
- for (int j = i+1; j < count; j++) {
536
+ for (int j = i + 1; j < count; j++) {
566
537
  float d = values[j];
567
538
  if ((d == d) && (d < m)) {
568
539
  m = values[j];
@@ -575,13 +546,11 @@ public class FloatDict {
575
546
  return mi;
576
547
  }
577
548
 
578
-
579
549
  // return the key for the minimum value
580
-
581
- /**
582
- *
583
- * @return
584
- */
550
+ /**
551
+ *
552
+ * @return
553
+ */
585
554
  public String minKey() {
586
555
  checkMinMax("minKey");
587
556
  int index = minIndex();
@@ -591,13 +560,11 @@ public class FloatDict {
591
560
  return keys[index];
592
561
  }
593
562
 
594
-
595
563
  // return the minimum value, or throw an error if there are no values
596
-
597
- /**
598
- *
599
- * @return
600
- */
564
+ /**
565
+ *
566
+ * @return
567
+ */
601
568
  public float minValue() {
602
569
  checkMinMax("minValue");
603
570
  int index = minIndex();
@@ -607,10 +574,8 @@ public class FloatDict {
607
574
  return values[index];
608
575
  }
609
576
 
610
-
611
577
  /**
612
- * @return
613
- * @webref floatlist:method
578
+ * @return @webref floatlist:method
614
579
  * @brief Return the largest value
615
580
  */
616
581
  // The index of the entry that has the max value. Reference above is incorrect.
@@ -629,7 +594,7 @@ public class FloatDict {
629
594
  mi = i;
630
595
 
631
596
  // calculate the rest
632
- for (int j = i+1; j < count; j++) {
597
+ for (int j = i + 1; j < count; j++) {
633
598
  float d = values[j];
634
599
  if (!Float.isNaN(d) && (d > m)) {
635
600
  m = values[j];
@@ -642,9 +607,11 @@ public class FloatDict {
642
607
  return mi;
643
608
  }
644
609
 
645
-
646
- /** The key for a max value; null if empty or everything is NaN (no max).
647
- * @return */
610
+ /**
611
+ * The key for a max value; null if empty or everything is NaN (no max).
612
+ *
613
+ * @return
614
+ */
648
615
  public String maxKey() {
649
616
  //checkMinMax("maxKey");
650
617
  int index = maxIndex();
@@ -654,9 +621,11 @@ public class FloatDict {
654
621
  return keys[index];
655
622
  }
656
623
 
657
-
658
- /** * The max value.(Or NaN if no entries or they're all NaN.)
659
- * @return */
624
+ /**
625
+ * * The max value.(Or NaN if no entries or they're all NaN.)
626
+ *
627
+ * @return
628
+ */
660
629
  public float maxValue() {
661
630
  //checkMinMax("maxValue");
662
631
  int index = maxIndex();
@@ -666,11 +635,11 @@ public class FloatDict {
666
635
  return values[index];
667
636
  }
668
637
 
669
- /**
670
- *
671
- * @return
672
- */
673
- public float sum() {
638
+ /**
639
+ *
640
+ * @return
641
+ */
642
+ public float sum() {
674
643
  double amount = sumDouble();
675
644
  if (amount > Float.MAX_VALUE) {
676
645
  throw new RuntimeException("sum() exceeds " + Float.MAX_VALUE + ", use sumDouble()");
@@ -681,11 +650,11 @@ public class FloatDict {
681
650
  return (float) amount;
682
651
  }
683
652
 
684
- /**
685
- *
686
- * @return
687
- */
688
- public double sumDouble() {
653
+ /**
654
+ *
655
+ * @return
656
+ */
657
+ public double sumDouble() {
689
658
  double sum = 0;
690
659
  for (int i = 0; i < count; i++) {
691
660
  sum += values[i];
@@ -693,36 +662,35 @@ public class FloatDict {
693
662
  return sum;
694
663
  }
695
664
 
696
- /**
697
- *
698
- * @param what
699
- * @return
700
- */
701
- public int index(String what) {
665
+ /**
666
+ *
667
+ * @param what
668
+ * @return
669
+ */
670
+ public int index(String what) {
702
671
  Integer found = indices.get(what);
703
- return (found == null) ? -1 : found.intValue();
672
+ return (found == null) ? -1 : found;
704
673
  }
705
674
 
706
- /**
707
- *
708
- * @param what
709
- * @param much
710
- */
711
- protected void create(String what, float much) {
675
+ /**
676
+ *
677
+ * @param what
678
+ * @param much
679
+ */
680
+ protected void create(String what, float much) {
712
681
  if (count == keys.length) {
713
682
  keys = PApplet.expand(keys);
714
683
  values = PApplet.expand(values);
715
684
  }
716
- indices.put(what, Integer.valueOf(count));
685
+ indices.put(what, count);
717
686
  keys[count] = what;
718
687
  values[count] = much;
719
688
  count++;
720
689
  }
721
690
 
722
-
723
691
  /**
724
- * @param key
725
- * @return
692
+ * @param key
693
+ * @return
726
694
  * @webref floatdict:method
727
695
  * @brief Remove a key/value pair
728
696
  */
@@ -734,21 +702,21 @@ public class FloatDict {
734
702
  return index;
735
703
  }
736
704
 
737
- /**
738
- *
739
- * @param index
740
- * @return
741
- */
742
- public String removeIndex(int index) {
705
+ /**
706
+ *
707
+ * @param index
708
+ * @return
709
+ */
710
+ public String removeIndex(int index) {
743
711
  if (index < 0 || index >= count) {
744
712
  throw new ArrayIndexOutOfBoundsException(index);
745
713
  }
746
714
  String key = keys[index];
747
715
  //System.out.println("index is " + which + " and " + keys[which]);
748
716
  indices.remove(keys[index]);
749
- for (int i = index; i < count-1; i++) {
750
- keys[i] = keys[i+1];
751
- values[i] = values[i+1];
717
+ for (int i = index; i < count - 1; i++) {
718
+ keys[i] = keys[i + 1];
719
+ values[i] = values[i + 1];
752
720
  indices.put(keys[i], i);
753
721
  }
754
722
  count--;
@@ -757,12 +725,12 @@ public class FloatDict {
757
725
  return key;
758
726
  }
759
727
 
760
- /**
761
- *
762
- * @param a
763
- * @param b
764
- */
765
- public void swap(int a, int b) {
728
+ /**
729
+ *
730
+ * @param a
731
+ * @param b
732
+ */
733
+ public void swap(int a, int b) {
766
734
  String tkey = keys[a];
767
735
  float tvalue = values[a];
768
736
  keys[a] = keys[b];
@@ -774,7 +742,6 @@ public class FloatDict {
774
742
  // indices.put(keys[b], Integer.valueOf(b));
775
743
  }
776
744
 
777
-
778
745
  /**
779
746
  * Sort the keys alphabetically (ignoring case). Uses the value as a
780
747
  * tie-breaker (only really possible with a key that has a case change).
@@ -786,7 +753,6 @@ public class FloatDict {
786
753
  sortImpl(true, false, true);
787
754
  }
788
755
 
789
-
790
756
  /**
791
757
  * @webref floatdict:method
792
758
  * @brief Sort the keys alphabetically in reverse
@@ -795,7 +761,6 @@ public class FloatDict {
795
761
  sortImpl(true, true, true);
796
762
  }
797
763
 
798
-
799
764
  /**
800
765
  * Sort by values in descending order (largest value will be at [0]).
801
766
  *
@@ -806,17 +771,16 @@ public class FloatDict {
806
771
  sortValues(true);
807
772
  }
808
773
 
809
-
810
774
  /**
811
- * Set true to ensure that the order returned is identical. Slightly
812
- * slower because the tie-breaker for identical values compares the keys.
775
+ * Set true to ensure that the order returned is identical. Slightly slower
776
+ * because the tie-breaker for identical values compares the keys.
777
+ *
813
778
  * @param stable
814
779
  */
815
780
  public void sortValues(boolean stable) {
816
781
  sortImpl(false, false, stable);
817
782
  }
818
783
 
819
-
820
784
  /**
821
785
  * @webref floatdict:method
822
786
  * @brief Sort by values in descending order
@@ -825,22 +789,22 @@ public class FloatDict {
825
789
  sortValuesReverse(true);
826
790
  }
827
791
 
828
- /**
829
- *
830
- * @param stable
831
- */
832
- public void sortValuesReverse(boolean stable) {
792
+ /**
793
+ *
794
+ * @param stable
795
+ */
796
+ public void sortValuesReverse(boolean stable) {
833
797
  sortImpl(false, true, stable);
834
798
  }
835
799
 
836
- /**
837
- *
838
- * @param useKeys
839
- * @param reverse
840
- * @param stable
841
- */
842
- protected void sortImpl(final boolean useKeys, final boolean reverse,
843
- final boolean stable) {
800
+ /**
801
+ *
802
+ * @param useKeys
803
+ * @param reverse
804
+ * @param stable
805
+ */
806
+ protected void sortImpl(final boolean useKeys, final boolean reverse,
807
+ final boolean stable) {
844
808
  Sort s = new Sort() {
845
809
  @Override
846
810
  public int size() {
@@ -896,11 +860,12 @@ public class FloatDict {
896
860
  resetIndices();
897
861
  }
898
862
 
899
-
900
863
  /**
901
864
  * Sum all of the values in this dictionary, then return a new FloatDict of
902
865
  * each key, divided by the total sum. The total for all values will be ~1.0.
903
- * @return a FloatDict with the original keys, mapped to their pct of the total
866
+ *
867
+ * @return a FloatDict with the original keys, mapped to their pct of the
868
+ * total
904
869
  */
905
870
  public FloatDict getPercent() {
906
871
  double sum = sum();
@@ -912,9 +877,11 @@ public class FloatDict {
912
877
  return outgoing;
913
878
  }
914
879
 
915
-
916
- /** Returns a duplicate copy of this object.
917
- * @return */
880
+ /**
881
+ * Returns a duplicate copy of this object.
882
+ *
883
+ * @return
884
+ */
918
885
  public FloatDict copy() {
919
886
  FloatDict outgoing = new FloatDict(count);
920
887
  System.arraycopy(keys, 0, outgoing.keys, 0, count);
@@ -926,18 +893,18 @@ public class FloatDict {
926
893
  return outgoing;
927
894
  }
928
895
 
929
- /**
930
- *
931
- */
932
- public void print() {
896
+ /**
897
+ *
898
+ */
899
+ public void print() {
933
900
  for (int i = 0; i < size(); i++) {
934
901
  System.out.println(keys[i] + " = " + values[i]);
935
902
  }
936
903
  }
937
904
 
938
-
939
905
  /**
940
906
  * Write tab-delimited entries out to
907
+ *
941
908
  * @param writer
942
909
  */
943
910
  public void write(PrintWriter writer) {
@@ -947,24 +914,24 @@ public class FloatDict {
947
914
  writer.flush();
948
915
  }
949
916
 
950
-
951
917
  /**
952
918
  * Return this dictionary as a String in JSON format.
953
- * @return
919
+ *
920
+ * @return
954
921
  */
955
922
  public String toJSON() {
956
923
  StringList items = new StringList();
957
924
  for (int i = 0; i < count; i++) {
958
- items.append(JSONObject.quote(keys[i])+ ": " + values[i]);
925
+ items.append(JSONObject.quote(keys[i]) + ": " + values[i]);
959
926
  }
960
927
  return "{ " + items.join(", ") + " }";
961
928
  }
962
929
 
963
- /**
964
- *
965
- * @return
966
- */
967
- @Override
930
+ /**
931
+ *
932
+ * @return
933
+ */
934
+ @Override
968
935
  public String toString() {
969
936
  return getClass().getSimpleName() + " size=" + size() + " " + toJSON();
970
937
  }