1 /*
2 * jcollectd
3 * Copyright (C) 2009 Hyperic, Inc.
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; only version 2 of the License is applicable.
8 *
9 * This program is distributed in the hope that it will be useful, but
10 * WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License along
15 * with this program; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
17 */
19 package org.collectd.api;
21 import java.util.ArrayList;
22 import java.util.List;
24 /**
25 * Java representation of collectd/src/plugin.h:value_list_t structure.
26 */
27 public class ValueList extends PluginData {
29 private List<Number> _values = new ArrayList<Number>();
30 private DataSet _ds;
32 private long _interval = 0;
34 public ValueList() {
36 }
38 public ValueList(PluginData pd) {
39 super(pd);
40 }
42 public ValueList(ValueList vl) {
43 this((PluginData)vl);
44 _interval = vl._interval;
45 _values.addAll(vl.getValues());
46 _ds = vl._ds;
47 }
49 public List<Number> getValues() {
50 return _values;
51 }
53 public void setValues(List<Number> values) {
54 _values = values;
55 }
57 public void addValue(Number value) {
58 _values.add(value);
59 }
61 /* Used by the network parsing code */
62 public void clearValues () {
63 _values.clear ();
64 }
66 /**
67 * @deprecated Use {@link #getDataSet()} instead.
68 */
69 public List<DataSource> getDataSource() {
70 if (_ds == null)
71 return null;
72 return _ds.getDataSources ();
73 }
75 public DataSet getDataSet () {
76 return _ds;
77 }
79 public void setDataSet (DataSet ds) {
80 _ds = ds;
81 }
83 /**
84 * @deprecated Use {@link #setDataSet(DataSet)} instead.
85 */
86 public void setDataSource(List<DataSource> dsrc) {
87 _ds = new DataSet (_type, dsrc);
88 }
90 /**
91 * Returns the interval (in milliseconds) of the value list.
92 */
93 public long getInterval() {
94 return _interval;
95 }
97 /**
98 * Sets the interval (in milliseconds) of the value list.
99 */
100 public void setInterval(long interval) {
101 _interval = interval;
102 }
104 public String toString() {
105 StringBuffer sb = new StringBuffer(super.toString());
106 sb.append("=[");
107 List<DataSource> ds = getDataSource();
108 int size = _values.size();
109 for (int i=0; i<size; i++) {
110 Number val = _values.get(i);
111 String name;
112 if (ds == null) {
113 name = "unknown" + i;
114 }
115 else {
116 name = ds.get(i).getName();
117 }
118 sb.append(name).append('=').append(val);
119 if (i < size-1) {
120 sb.append(',');
121 }
122 }
123 sb.append("]");
124 return sb.toString();
125 }
126 }
128 /* vim: set sw=4 sts=4 et : */