
org.snmp4j.smi.TimeTicks Maven / Gradle / Ivy
/*_############################################################################
_##
_## SNMP4J - TimeTicks.java
_##
_## Copyright (C) 2003-2018 Frank Fock and Jochen Katz (SNMP4J.org)
_##
_## Licensed under the Apache License, Version 2.0 (the "License");
_## you may not use this file except in compliance with the License.
_## You may obtain a copy of the License at
_##
_## http://www.apache.org/licenses/LICENSE-2.0
_##
_## Unless required by applicable law or agreed to in writing, software
_## distributed under the License is distributed on an "AS IS" BASIS,
_## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
_## See the License for the specific language governing permissions and
_## limitations under the License.
_##
_##########################################################################*/
package org.snmp4j.smi;
import java.io.*;
import java.text.MessageFormat;
import org.snmp4j.asn1.BER;
import org.snmp4j.asn1.BERInputStream;
/**
* The TimeTicks
class represents the time in 1/100 seconds
* since some epoch (which should be have been defined in the
* corresponding MIB specification).
*
* @author Frank Fock
* @version 1.7
*/
public class TimeTicks extends UnsignedInteger32 {
private static final long serialVersionUID = 8663761323061572311L;
private static final String FORMAT_PATTERN =
"{0,choice,0#|1#1 day, |1<{0,number,integer} days, }"+
"{1,number,integer}:{2,number,00}:{3,number,00}.{4,number,00}";
private static final int[] FORMAT_FACTORS = { 24*60*60*100, 60*60*100, 60*100, 100, 1 };
public TimeTicks() {
}
/**
* Copy constructor.
* @param other
* a TimeTicks instance.
* @since 1.7
*/
public TimeTicks(TimeTicks other) {
this.value = other.value;
}
public TimeTicks(long value) {
super(value);
}
public Object clone() {
return new TimeTicks(value);
}
public int getSyntax() {
return SMIConstants.SYNTAX_TIMETICKS;
}
public void encodeBER(OutputStream os) throws IOException {
BER.encodeUnsignedInteger(os, BER.TIMETICKS, super.getValue());
}
public void decodeBER(BERInputStream inputStream) throws IOException {
BER.MutableByte type = new BER.MutableByte();
long newValue = BER.decodeUnsignedInteger(inputStream, type);
if (type.getValue() != BER.TIMETICKS) {
throw new IOException("Wrong type encountered when decoding TimeTicks: "+type.getValue());
}
setValue(newValue);
}
/**
* Returns string with the value of this TimeTicks
object as
* "[days,]hh:mm:ss.hh".
*
* @return
* a String
representation of this object.
*/
public String toString() {
return toString(FORMAT_PATTERN);
}
@Override
/**
* Sets the value of this TimeTicks instance from a string.
*
* @param value
* a string representation of this value, which is
* (a) is either an unsigned number or
* (b) matches the format {@link FORMAT_PATTERN}.
* @since 2.1.2
*/
public final void setValue(String value) {
try {
long v = Long.parseLong(value);
setValue(v);
}
catch (NumberFormatException nfe) {
long v = 0;
String[] num = value.split("[days :,\\.]");
int i = 0;
for (String n : num) {
if (n.length()>0) {
long f = FORMAT_FACTORS[i++];
v += Long.parseLong(n)*f;
}
}
setValue(v);
}
}
/**
* Formats the content of this TimeTicks
object according to
* a supplied MessageFormat
pattern.
* @param pattern
* a MessageFormat
pattern that takes up to five parameters
* which are: days, hours, minutes, seconds, and 1/100 seconds.
* @return
* the formatted string representation.
*/
public String toString(String pattern) {
long hseconds, seconds, minutes, hours, days;
long tt = getValue();
days = tt / 8640000;
tt %= 8640000;
hours = tt / 360000;
tt %= 360000;
minutes = tt / 6000;
tt %= 6000;
seconds = tt / 100;
tt %= 100;
hseconds = tt;
Long[] values = new Long[5];
values[0] = days;
values[1] = hours;
values[2] = minutes;
values[3] = seconds;
values[4] = hseconds;
return MessageFormat.format(pattern, (Object[])values);
}
/**
* Returns the timeticks value as milliseconds (instead 1/100 seconds).
* @return
* getValue()*10
.
* @since 1.7
*/
public long toMilliseconds() {
return value*10;
}
/**
* Sets the timeticks value by milliseconds.
* @param millis
* sets the value as setValue(millis/10)
.
* @since 1.7
*/
public void fromMilliseconds(long millis) {
setValue(millis/10);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy