📄 oid.h
字号:
/*=================================================================== 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. SNMP++ O I D. H OID CLASS DEFINITION VERSION: 2.8 RCS INFO: $Header: oid.h,v 1.28 96/09/11 14:01:32 hmgr Exp $ DESIGN: Peter E Mellquist AUTHOR: Peter E Mellquist LANGUAGE: ANSI C++ OPERATING SYSTEMS: MS-Windows Win32 BSD UNIX DESCRIPTION: This class is fully contained and does not rely on or any other SNMP libraries. This class is portable across any platform which supports C++.=====================================================================*/#ifndef _OID_CLS#define _OID_CLS//------------------------------------------------------------------------//----------[ extern C libraries Needed ]---------------------------------extern "C"{#include <memory.h> // memcpy's#include <string.h> // strlen, etc..}#include "smival.h" // derived class for all values#include "collect.h"//-----------------------------------------------------------------------//------------[ SNMP++ OID CLASS DEF ]----------------------------------//-----------------------------------------------------------------------class DLLOPT Oid: public SnmpSyntax {public: // constructor using no arguments // initialize octet ptr and string // ptr to null Oid( void); // constructor using a dotted string Oid( const char * dotted_oid_string); // constructor using another oid object Oid ( const Oid &oid); // constructor from raw form Oid(const unsigned long *raw_oid, int oid_len); // destructor ~Oid(); // syntax type SmiUINT32 get_syntax(); // assignment to a string operator overloaded Oid& operator=( const char *dotted_oid_string); // assignment to another oid object overloaded Oid& operator=( const Oid &oid); // equal operator overloaded DLLOPT friend int operator==( const Oid &lhs,const Oid &rhs); // not equal operator overloaded DLLOPT friend int operator!=( const Oid &lhs,const Oid &rhs); // less than < overloaded DLLOPT friend int operator<( const Oid &lhs,const Oid &rhs); // less than <= overloaded DLLOPT friend int operator<=( const Oid &lhs,const Oid &rhs); // greater than > overloaded DLLOPT friend int operator>( const Oid &lhs,const Oid &rhs); // greater than >= overloaded DLLOPT friend int operator>=( const Oid &lhs,const Oid &rhs); // equal operator overloaded DLLOPT friend int operator==( const Oid &lhs,const char *rhs); // not equal operator overloaded DLLOPT friend int operator!=( const Oid &lhs,const char *rhs); // less than < operator overloaded DLLOPT friend int operator<( const Oid &lhs,const char *rhs); // less than <= operator overloaded DLLOPT friend int operator<=( const Oid &lhs,char *rhs); // greater than > operator overloaded DLLOPT friend int operator>( const Oid &lhs,const char *rhs); // greater than >= operator overloaded DLLOPT friend int operator>=( const Oid &lhs,const char *rhs); // append operator, appends a string Oid& operator+=( const char *a); // appends an int Oid& operator+=( const unsigned long i); // appends an Oid Oid& operator+=( const Oid &o); // allows element access unsigned long & operator[]( int position); // return the WinSnmp oid part SmiLPOID oidval(); // reset the data from raw form void set_data( const unsigned long *raw_oid, const unsigned int oid_len); // return the len of the oid unsigned long len() const; // trim off the n rightmost values of an oid void trim( const unsigned long n=1); // compare the n leftmost bytes (left-to-right) // returns 0, equal // returns -1, < // returns 1 , > int nCompare( const unsigned long n, const Oid &o) const; // compare the n rightmost bytes (right-to-left) // returns 0, equal // returns -1, < // returns 1 , > int RnCompare( const unsigned long n, const Oid &o) const; // is the Oid object valid // returns validity int valid() const; // get a printable ASCII value char * get_printable(); // get printable // return dotted string value from the right // where the user specifies how many positions to print // char * get_printable( const unsigned long n); // return a dotted string starting at start, // going n positions to the left // NOTE, start is 1 based ( the first id is at position #1) char * get_printable( const unsigned long start, const unsigned long n); // create a new instance of this Value SnmpSyntax *clone() const; // copy an instance of this Value SnmpSyntax& operator=( SnmpSyntax &val);protected: //----[ instance variables ] char *iv_str; // used for returning oid string //----[ protected member functions ] // convert a string to an smi oid int StrToOid( const char *string, // input string SmiLPOID dstOid); // destination oid // clone an smi oid int OidCopy( SmiLPOID srcOid, // source oid SmiLPOID dstOid); // destination oid // convert an smi oid to its string representation int OidToStr(SmiLPOID srcOid, // source oid SmiUINT32 size, // size of string char *string); // pointer to string};//-----------[ End Oid Class ]-------------------------------------// create OidCollection typetypedef SnmpCollection <Oid> OidCollection;#endif //_OID_CLS
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -