001// Copyright (c) FIRST and other WPILib contributors.
002// Open Source Software; you can modify and/or share it under the terms of
003// the WPILib BSD license file in the root directory of this project.
004
005// THIS FILE WAS AUTO-GENERATED BY ./ntcore/generate_topics.py. DO NOT MODIFY
006
007package edu.wpi.first.networktables;
008
009import java.util.Objects;
010
011/** A network table entry value. */
012@SuppressWarnings({"UnnecessaryParentheses", "PMD.MethodReturnsInternalArray"})
013public final class NetworkTableValue {
014  NetworkTableValue(NetworkTableType type, Object value, long time, long serverTime) {
015    m_type = type;
016    m_value = value;
017    m_time = time;
018    m_serverTime = serverTime;
019  }
020
021  NetworkTableValue(NetworkTableType type, Object value, long time) {
022    this(type, value, time, time == 0 ? 0 : 1);
023  }
024
025  NetworkTableValue(NetworkTableType type, Object value) {
026    this(type, value, NetworkTablesJNI.now(), 1);
027  }
028
029  NetworkTableValue(int type, Object value, long time, long serverTime) {
030    this(NetworkTableType.getFromInt(type), value, time, serverTime);
031  }
032
033  /**
034   * Get the data type.
035   *
036   * @return The type.
037   */
038  public NetworkTableType getType() {
039    return m_type;
040  }
041
042  /**
043   * Get the data value stored.
044   *
045   * @return The type.
046   */
047  public Object getValue() {
048    return m_value;
049  }
050
051  /**
052   * Get the creation time of the value in local time.
053   *
054   * @return The time, in the units returned by NetworkTablesJNI.now().
055   */
056  public long getTime() {
057    return m_time;
058  }
059
060  /**
061   * Get the creation time of the value in server time.
062   *
063   * @return The server time.
064   */
065  public long getServerTime() {
066    return m_serverTime;
067  }
068
069  /*
070   * Type Checkers
071   */
072
073  /**
074   * Determine if entry value contains a value or is unassigned.
075   *
076   * @return True if the entry value contains a value.
077   */
078  public boolean isValid() {
079    return m_type != NetworkTableType.kUnassigned;
080  }
081
082  /**
083   * Determine if entry value contains a boolean.
084   *
085   * @return True if the entry value is of boolean type.
086   */
087  public boolean isBoolean() {
088    return m_type == NetworkTableType.kBoolean;
089  }
090
091  /**
092   * Determine if entry value contains a long.
093   *
094   * @return True if the entry value is of long type.
095   */
096  public boolean isInteger() {
097    return m_type == NetworkTableType.kInteger;
098  }
099
100  /**
101   * Determine if entry value contains a float.
102   *
103   * @return True if the entry value is of float type.
104   */
105  public boolean isFloat() {
106    return m_type == NetworkTableType.kFloat;
107  }
108
109  /**
110   * Determine if entry value contains a double.
111   *
112   * @return True if the entry value is of double type.
113   */
114  public boolean isDouble() {
115    return m_type == NetworkTableType.kDouble;
116  }
117
118  /**
119   * Determine if entry value contains a String.
120   *
121   * @return True if the entry value is of String type.
122   */
123  public boolean isString() {
124    return m_type == NetworkTableType.kString;
125  }
126
127  /**
128   * Determine if entry value contains a byte[].
129   *
130   * @return True if the entry value is of byte[] type.
131   */
132  public boolean isRaw() {
133    return m_type == NetworkTableType.kRaw;
134  }
135
136  /**
137   * Determine if entry value contains a boolean[].
138   *
139   * @return True if the entry value is of boolean[] type.
140   */
141  public boolean isBooleanArray() {
142    return m_type == NetworkTableType.kBooleanArray;
143  }
144
145  /**
146   * Determine if entry value contains a long[].
147   *
148   * @return True if the entry value is of long[] type.
149   */
150  public boolean isIntegerArray() {
151    return m_type == NetworkTableType.kIntegerArray;
152  }
153
154  /**
155   * Determine if entry value contains a float[].
156   *
157   * @return True if the entry value is of float[] type.
158   */
159  public boolean isFloatArray() {
160    return m_type == NetworkTableType.kFloatArray;
161  }
162
163  /**
164   * Determine if entry value contains a double[].
165   *
166   * @return True if the entry value is of double[] type.
167   */
168  public boolean isDoubleArray() {
169    return m_type == NetworkTableType.kDoubleArray;
170  }
171
172  /**
173   * Determine if entry value contains a String[].
174   *
175   * @return True if the entry value is of String[] type.
176   */
177  public boolean isStringArray() {
178    return m_type == NetworkTableType.kStringArray;
179  }
180
181  /*
182   * Type-Safe Getters
183   */
184
185  /**
186   * Get the boolean value.
187   *
188   * @return The boolean value.
189   * @throws ClassCastException if the entry value is not of boolean type.
190   */
191  public boolean getBoolean() {
192    if (m_type != NetworkTableType.kBoolean) {
193      throw new ClassCastException("cannot convert " + m_type + " to boolean");
194    }
195    return (Boolean) m_value;
196  }
197
198  /**
199   * Get the long value.
200   *
201   * @return The long value.
202   * @throws ClassCastException if the entry value is not of long type.
203   */
204  public long getInteger() {
205    if (m_type != NetworkTableType.kInteger) {
206      throw new ClassCastException("cannot convert " + m_type + " to long");
207    }
208    return ((Number) m_value).longValue();
209  }
210
211  /**
212   * Get the float value.
213   *
214   * @return The float value.
215   * @throws ClassCastException if the entry value is not of float type.
216   */
217  public float getFloat() {
218    if (m_type != NetworkTableType.kFloat) {
219      throw new ClassCastException("cannot convert " + m_type + " to float");
220    }
221    return ((Number) m_value).floatValue();
222  }
223
224  /**
225   * Get the double value.
226   *
227   * @return The double value.
228   * @throws ClassCastException if the entry value is not of double type.
229   */
230  public double getDouble() {
231    if (m_type != NetworkTableType.kDouble) {
232      throw new ClassCastException("cannot convert " + m_type + " to double");
233    }
234    return ((Number) m_value).doubleValue();
235  }
236
237  /**
238   * Get the String value.
239   *
240   * @return The String value.
241   * @throws ClassCastException if the entry value is not of String type.
242   */
243  public String getString() {
244    if (m_type != NetworkTableType.kString) {
245      throw new ClassCastException("cannot convert " + m_type + " to String");
246    }
247    return (String) m_value;
248  }
249
250  /**
251   * Get the byte[] value.
252   *
253   * @return The byte[] value.
254   * @throws ClassCastException if the entry value is not of byte[] type.
255   */
256  public byte[] getRaw() {
257    if (m_type != NetworkTableType.kRaw) {
258      throw new ClassCastException("cannot convert " + m_type + " to byte[]");
259    }
260    return (byte[]) m_value;
261  }
262
263  /**
264   * Get the boolean[] value.
265   *
266   * @return The boolean[] value.
267   * @throws ClassCastException if the entry value is not of boolean[] type.
268   */
269  public boolean[] getBooleanArray() {
270    if (m_type != NetworkTableType.kBooleanArray) {
271      throw new ClassCastException("cannot convert " + m_type + " to boolean[]");
272    }
273    return (boolean[]) m_value;
274  }
275
276  /**
277   * Get the long[] value.
278   *
279   * @return The long[] value.
280   * @throws ClassCastException if the entry value is not of long[] type.
281   */
282  public long[] getIntegerArray() {
283    if (m_type != NetworkTableType.kIntegerArray) {
284      throw new ClassCastException("cannot convert " + m_type + " to long[]");
285    }
286    return (long[]) m_value;
287  }
288
289  /**
290   * Get the float[] value.
291   *
292   * @return The float[] value.
293   * @throws ClassCastException if the entry value is not of float[] type.
294   */
295  public float[] getFloatArray() {
296    if (m_type != NetworkTableType.kFloatArray) {
297      throw new ClassCastException("cannot convert " + m_type + " to float[]");
298    }
299    return (float[]) m_value;
300  }
301
302  /**
303   * Get the double[] value.
304   *
305   * @return The double[] value.
306   * @throws ClassCastException if the entry value is not of double[] type.
307   */
308  public double[] getDoubleArray() {
309    if (m_type != NetworkTableType.kDoubleArray) {
310      throw new ClassCastException("cannot convert " + m_type + " to double[]");
311    }
312    return (double[]) m_value;
313  }
314
315  /**
316   * Get the String[] value.
317   *
318   * @return The String[] value.
319   * @throws ClassCastException if the entry value is not of String[] type.
320   */
321  public String[] getStringArray() {
322    if (m_type != NetworkTableType.kStringArray) {
323      throw new ClassCastException("cannot convert " + m_type + " to String[]");
324    }
325    return (String[]) m_value;
326  }
327
328  /*
329   * Factory functions.
330   */
331
332  /**
333   * Creates a boolean value.
334   *
335   * @param value the value
336   * @return The entry value
337   */
338  public static NetworkTableValue makeBoolean(boolean value) {
339    return new NetworkTableValue(NetworkTableType.kBoolean, Boolean.valueOf(value));
340  }
341
342  /**
343   * Creates a boolean value.
344   *
345   * @param value the value
346   * @param time the creation time to use (instead of the current time)
347   * @return The entry value
348   */
349  public static NetworkTableValue makeBoolean(boolean value, long time) {
350    return new NetworkTableValue(NetworkTableType.kBoolean, Boolean.valueOf(value), time);
351  }
352
353  /**
354   * Creates a long value.
355   *
356   * @param value the value
357   * @return The entry value
358   */
359  public static NetworkTableValue makeInteger(long value) {
360    return new NetworkTableValue(NetworkTableType.kInteger, Long.valueOf(value));
361  }
362
363  /**
364   * Creates a long value.
365   *
366   * @param value the value
367   * @param time the creation time to use (instead of the current time)
368   * @return The entry value
369   */
370  public static NetworkTableValue makeInteger(long value, long time) {
371    return new NetworkTableValue(NetworkTableType.kInteger, Long.valueOf(value), time);
372  }
373
374  /**
375   * Creates a float value.
376   *
377   * @param value the value
378   * @return The entry value
379   */
380  public static NetworkTableValue makeFloat(float value) {
381    return new NetworkTableValue(NetworkTableType.kFloat, Float.valueOf(value));
382  }
383
384  /**
385   * Creates a float value.
386   *
387   * @param value the value
388   * @param time the creation time to use (instead of the current time)
389   * @return The entry value
390   */
391  public static NetworkTableValue makeFloat(float value, long time) {
392    return new NetworkTableValue(NetworkTableType.kFloat, Float.valueOf(value), time);
393  }
394
395  /**
396   * Creates a double value.
397   *
398   * @param value the value
399   * @return The entry value
400   */
401  public static NetworkTableValue makeDouble(double value) {
402    return new NetworkTableValue(NetworkTableType.kDouble, Double.valueOf(value));
403  }
404
405  /**
406   * Creates a double value.
407   *
408   * @param value the value
409   * @param time the creation time to use (instead of the current time)
410   * @return The entry value
411   */
412  public static NetworkTableValue makeDouble(double value, long time) {
413    return new NetworkTableValue(NetworkTableType.kDouble, Double.valueOf(value), time);
414  }
415
416  /**
417   * Creates a String value.
418   *
419   * @param value the value
420   * @return The entry value
421   */
422  public static NetworkTableValue makeString(String value) {
423    return new NetworkTableValue(NetworkTableType.kString, (value));
424  }
425
426  /**
427   * Creates a String value.
428   *
429   * @param value the value
430   * @param time the creation time to use (instead of the current time)
431   * @return The entry value
432   */
433  public static NetworkTableValue makeString(String value, long time) {
434    return new NetworkTableValue(NetworkTableType.kString, (value), time);
435  }
436
437  /**
438   * Creates a byte[] value.
439   *
440   * @param value the value
441   * @return The entry value
442   */
443  public static NetworkTableValue makeRaw(byte[] value) {
444    return new NetworkTableValue(NetworkTableType.kRaw, (value));
445  }
446
447  /**
448   * Creates a byte[] value.
449   *
450   * @param value the value
451   * @param time the creation time to use (instead of the current time)
452   * @return The entry value
453   */
454  public static NetworkTableValue makeRaw(byte[] value, long time) {
455    return new NetworkTableValue(NetworkTableType.kRaw, (value), time);
456  }
457
458  /**
459   * Creates a boolean[] value.
460   *
461   * @param value the value
462   * @return The entry value
463   */
464  public static NetworkTableValue makeBooleanArray(boolean[] value) {
465    return new NetworkTableValue(NetworkTableType.kBooleanArray, (value));
466  }
467
468  /**
469   * Creates a boolean[] value.
470   *
471   * @param value the value
472   * @param time the creation time to use (instead of the current time)
473   * @return The entry value
474   */
475  public static NetworkTableValue makeBooleanArray(boolean[] value, long time) {
476    return new NetworkTableValue(NetworkTableType.kBooleanArray, (value), time);
477  }
478
479  /**
480   * Creates a boolean[] value.
481   *
482   * @param value the value
483   * @return The entry value
484   */
485  public static NetworkTableValue makeBooleanArray(Boolean[] value) {
486    return new NetworkTableValue(NetworkTableType.kBooleanArray, toNativeBooleanArray(value));
487  }
488
489  /**
490   * Creates a boolean[] value.
491   *
492   * @param value the value
493   * @param time the creation time to use (instead of the current time)
494   * @return The entry value
495   */
496  public static NetworkTableValue makeBooleanArray(Boolean[] value, long time) {
497    return new NetworkTableValue(NetworkTableType.kBooleanArray, toNativeBooleanArray(value), time);
498  }
499
500  /**
501   * Creates a long[] value.
502   *
503   * @param value the value
504   * @return The entry value
505   */
506  public static NetworkTableValue makeIntegerArray(long[] value) {
507    return new NetworkTableValue(NetworkTableType.kIntegerArray, (value));
508  }
509
510  /**
511   * Creates a long[] value.
512   *
513   * @param value the value
514   * @param time the creation time to use (instead of the current time)
515   * @return The entry value
516   */
517  public static NetworkTableValue makeIntegerArray(long[] value, long time) {
518    return new NetworkTableValue(NetworkTableType.kIntegerArray, (value), time);
519  }
520
521  /**
522   * Creates a long[] value.
523   *
524   * @param value the value
525   * @return The entry value
526   */
527  public static NetworkTableValue makeIntegerArray(Long[] value) {
528    return new NetworkTableValue(NetworkTableType.kIntegerArray, toNativeIntegerArray(value));
529  }
530
531  /**
532   * Creates a long[] value.
533   *
534   * @param value the value
535   * @param time the creation time to use (instead of the current time)
536   * @return The entry value
537   */
538  public static NetworkTableValue makeIntegerArray(Long[] value, long time) {
539    return new NetworkTableValue(NetworkTableType.kIntegerArray, toNativeIntegerArray(value), time);
540  }
541
542  /**
543   * Creates a float[] value.
544   *
545   * @param value the value
546   * @return The entry value
547   */
548  public static NetworkTableValue makeFloatArray(float[] value) {
549    return new NetworkTableValue(NetworkTableType.kFloatArray, (value));
550  }
551
552  /**
553   * Creates a float[] value.
554   *
555   * @param value the value
556   * @param time the creation time to use (instead of the current time)
557   * @return The entry value
558   */
559  public static NetworkTableValue makeFloatArray(float[] value, long time) {
560    return new NetworkTableValue(NetworkTableType.kFloatArray, (value), time);
561  }
562
563  /**
564   * Creates a float[] value.
565   *
566   * @param value the value
567   * @return The entry value
568   */
569  public static NetworkTableValue makeFloatArray(Float[] value) {
570    return new NetworkTableValue(NetworkTableType.kFloatArray, toNativeFloatArray(value));
571  }
572
573  /**
574   * Creates a float[] value.
575   *
576   * @param value the value
577   * @param time the creation time to use (instead of the current time)
578   * @return The entry value
579   */
580  public static NetworkTableValue makeFloatArray(Float[] value, long time) {
581    return new NetworkTableValue(NetworkTableType.kFloatArray, toNativeFloatArray(value), time);
582  }
583
584  /**
585   * Creates a double[] value.
586   *
587   * @param value the value
588   * @return The entry value
589   */
590  public static NetworkTableValue makeDoubleArray(double[] value) {
591    return new NetworkTableValue(NetworkTableType.kDoubleArray, (value));
592  }
593
594  /**
595   * Creates a double[] value.
596   *
597   * @param value the value
598   * @param time the creation time to use (instead of the current time)
599   * @return The entry value
600   */
601  public static NetworkTableValue makeDoubleArray(double[] value, long time) {
602    return new NetworkTableValue(NetworkTableType.kDoubleArray, (value), time);
603  }
604
605  /**
606   * Creates a double[] value.
607   *
608   * @param value the value
609   * @return The entry value
610   */
611  public static NetworkTableValue makeDoubleArray(Double[] value) {
612    return new NetworkTableValue(NetworkTableType.kDoubleArray, toNativeDoubleArray(value));
613  }
614
615  /**
616   * Creates a double[] value.
617   *
618   * @param value the value
619   * @param time the creation time to use (instead of the current time)
620   * @return The entry value
621   */
622  public static NetworkTableValue makeDoubleArray(Double[] value, long time) {
623    return new NetworkTableValue(NetworkTableType.kDoubleArray, toNativeDoubleArray(value), time);
624  }
625
626  /**
627   * Creates a String[] value.
628   *
629   * @param value the value
630   * @return The entry value
631   */
632  public static NetworkTableValue makeStringArray(String[] value) {
633    return new NetworkTableValue(NetworkTableType.kStringArray, (value));
634  }
635
636  /**
637   * Creates a String[] value.
638   *
639   * @param value the value
640   * @param time the creation time to use (instead of the current time)
641   * @return The entry value
642   */
643  public static NetworkTableValue makeStringArray(String[] value, long time) {
644    return new NetworkTableValue(NetworkTableType.kStringArray, (value), time);
645  }
646
647  @Override
648  public boolean equals(Object other) {
649    return other == this
650        || other instanceof NetworkTableValue ntOther
651            && m_type == ntOther.m_type
652            && m_value.equals(ntOther.m_value);
653  }
654
655  @Override
656  public int hashCode() {
657    return Objects.hash(m_type, m_value);
658  }
659
660  // arraycopy() doesn't know how to unwrap boxed values; this is a false positive in PMD
661  // (see https://sourceforge.net/p/pmd/bugs/804/)
662  @SuppressWarnings("PMD.AvoidArrayLoops")
663  static boolean[] toNativeBooleanArray(Boolean[] arr) {
664    boolean[] out = new boolean[arr.length];
665    for (int i = 0; i < arr.length; i++) {
666      out[i] = arr[i];
667    }
668    return out;
669  }
670
671  @SuppressWarnings("PMD.AvoidArrayLoops")
672  static double[] toNativeDoubleArray(Number[] arr) {
673    double[] out = new double[arr.length];
674    for (int i = 0; i < arr.length; i++) {
675      out[i] = arr[i].doubleValue();
676    }
677    return out;
678  }
679
680  @SuppressWarnings("PMD.AvoidArrayLoops")
681  static long[] toNativeIntegerArray(Number[] arr) {
682    long[] out = new long[arr.length];
683    for (int i = 0; i < arr.length; i++) {
684      out[i] = arr[i].longValue();
685    }
686    return out;
687  }
688
689  @SuppressWarnings("PMD.AvoidArrayLoops")
690  static float[] toNativeFloatArray(Number[] arr) {
691    float[] out = new float[arr.length];
692    for (int i = 0; i < arr.length; i++) {
693      out[i] = arr[i].floatValue();
694    }
695    return out;
696  }
697
698  @SuppressWarnings("PMD.AvoidArrayLoops")
699  static Boolean[] fromNativeBooleanArray(boolean[] arr) {
700    Boolean[] out = new Boolean[arr.length];
701    for (int i = 0; i < arr.length; i++) {
702      out[i] = arr[i];
703    }
704    return out;
705  }
706
707  @SuppressWarnings("PMD.AvoidArrayLoops")
708  static Long[] fromNativeIntegerArray(long[] arr) {
709    Long[] out = new Long[arr.length];
710    for (int i = 0; i < arr.length; i++) {
711      out[i] = arr[i];
712    }
713    return out;
714  }
715
716  @SuppressWarnings("PMD.AvoidArrayLoops")
717  static Float[] fromNativeFloatArray(float[] arr) {
718    Float[] out = new Float[arr.length];
719    for (int i = 0; i < arr.length; i++) {
720      out[i] = arr[i];
721    }
722    return out;
723  }
724
725  @SuppressWarnings("PMD.AvoidArrayLoops")
726  static Double[] fromNativeDoubleArray(double[] arr) {
727    Double[] out = new Double[arr.length];
728    for (int i = 0; i < arr.length; i++) {
729      out[i] = arr[i];
730    }
731    return out;
732  }
733
734  private NetworkTableType m_type;
735  private Object m_value;
736  private long m_time;
737  private long m_serverTime;
738}