summaryrefslogtreecommitdiff
path: root/ASNMP/asnmp/counter.cpp
blob: 1dc36008fce721e4c9355198e54b699593d8d5b0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/* -*-C++-*- */
// ============================================================================
//
// = LIBRARY
//    asnmp
//
// = FILENAME
//     counter.cpp
//
// = DESCRIPTION
//  Class implementation for SMI Counter32 class.
//
// = AUTHOR
//   Peter E Mellquist
//   Michael R MacFaden  mrm@cisco.com - rework & ACE port
// ============================================================================
/*===================================================================
  Copyright (c) 1996
  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. 
=====================================================================*/

#include "asnmp/counter.h"

// constructor with a value
Counter32::Counter32( const unsigned long i):SnmpUInt32(i)
{ 
  smival.syntax = sNMP_SYNTAX_CNTR32; 
}

// copy constructor
Counter32::Counter32( const Counter32 &c)
{ 
   this->smival.value.uNumber = c.smival.value.uNumber;
   smival.syntax = sNMP_SYNTAX_CNTR32;
   valid_flag = 1;
}

// syntax type
SmiUINT32 Counter32::get_syntax()
{ 
  return sNMP_SYNTAX_CNTR32; 
}

// general assignment from any Value
SnmpSyntax& Counter32::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 = 
		((Counter32 &)in_val).smival.value.uNumber;  
  	  valid_flag = 1;
	  break;
    }
  }
  return *this;
}

// overloaded assignment
Counter32& Counter32::operator=( const unsigned long int i)
{ 
  this->smival.value.uNumber=i; 
  return *this;
}

// overloaded assignment
Counter32& Counter32::operator=( const Counter32 &uli)
{ 
  this->smival.value.uNumber = uli.smival.value.uNumber;
  return *this;
}

// otherwise, behave like an unsigned long int
Counter32::operator unsigned long()
{ 
  return this->smival.value.uNumber; 
}

// clone
SnmpSyntax * Counter32::clone() const
{ 
  return ( SnmpSyntax *) new Counter32(*this); 
}