📄 timetick.cpp
字号:
/*=================================================================== Copyright (c) 1999 Hewlett-Packard Company ATTENTION: USE OF THIS SOFTWARE IS SUBJECT TO THE FOLLOWING TERMS. Permission to use, copy, modify, distribute and/or sell this software and/or its documentation is hereby granted without fee. User agrees to display the above copyright notice and this license notice in all copies of the software and any documentation of the software. User agrees to assume all liability for the use of the software; Hewlett-Packard makes no representations about the suitability of this software for any purpose. It is provided "AS-IS without warranty of any kind,either express or implied. User hereby grants a royalty-free license to any and all derivatives based upon this software code base. T I M E T I C K. C P P TIMETICK CLASS IMPLEMENTATION VERSION: 2.8 DESIGN: Peter E Mellquist AUTHOR: Peter E Mellquist LANGUAGE: ANSI C++ OPERATING SYSTEMS: MS-Windows Win32 BSD UNIX DESCRIPTION: Class implentation for SMI Timeticks class.=====================================================================*/char timetick_cpp_version[]="#(@)SNMP++ 2.8 $Header: timetick.cpp,v 1.11 96/09/11 14:02:12 hmgr Exp $";#include "timetick.h" // include header file for timetick class#include <stdio.h> // for sprintf() usage.// constructor no args TimeTicks::TimeTicks( void):SnmpUInt32() { smival.syntax = sNMP_SYNTAX_TIMETICKS; }; // constructor with a value TimeTicks::TimeTicks( const unsigned long i):SnmpUInt32(i) { smival.syntax = sNMP_SYNTAX_TIMETICKS;}; // copy constructorTimeTicks::TimeTicks( const TimeTicks &t) { smival.value.uNumber = t.smival.value.uNumber; smival.syntax = sNMP_SYNTAX_TIMETICKS;};// destructorTimeTicks::~TimeTicks() {}// syntax typeSmiUINT32 TimeTicks::get_syntax(){ return sNMP_SYNTAX_TIMETICKS; };// create a new instance of this ValueSnmpSyntax *TimeTicks::clone() const { return (SnmpSyntax *) new TimeTicks(*this); };// overloaded assignement from ulongTimeTicks& TimeTicks::operator=( const unsigned long int i){ smival.value.uNumber =i; return *this;};// overloaded assignment from TimeTicksTimeTicks& TimeTicks::operator=( const TimeTicks &uli){ this->smival.value.uNumber = uli.smival.value.uNumber; return *this;};// general assignment from any ValueSnmpSyntax& TimeTicks::operator=( SnmpSyntax &in_val){ if ( this == &in_val ) // handle assignement from itself return *this; valid_flag = 0; // will get set true if really valid if (in_val.valid()) { switch (in_val.get_syntax()) { case sNMP_SYNTAX_UINT32: // case sNMP_SYNTAX_GAUGE32: .. indistinquishable from UINT32 case sNMP_SYNTAX_CNTR32: case sNMP_SYNTAX_TIMETICKS: case sNMP_SYNTAX_INT32: // implied cast int -> uint this->smival.value.uNumber = ((TimeTicks &)in_val).smival.value.uNumber; valid_flag = 1; break; } } return *this;};// otherwise, behave like an unsigned longTimeTicks::operator unsigned long(){ return smival.value.uNumber; };// ASCII format returnchar * TimeTicks::get_printable() /* Should do something nicer like days:hours:minutes... */{ unsigned long tt, hseconds, seconds, minutes, hours, days; tt = this->smival.value.uNumber; // days days = tt / 8640000; tt %= 8640000; // hours hours = tt / 360000; tt %= 360000; // minutes minutes = tt / 6000; tt %= 6000; seconds = tt / 100; tt %= 100; hseconds = tt; if ( days ==0) sprintf( output_buffer,"%ld:%02ld:%02ld.%02ld", hours, minutes,seconds,hseconds); else if ( days==1) sprintf( output_buffer,"1 day %ld:%02ld:%02ld.%02ld", hours, minutes,seconds,hseconds); else sprintf( output_buffer,"%ld days, %ld:%02ld:%02ld.%02ld", days,hours, minutes,seconds,hseconds); return output_buffer;};
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -