//%///////////////////////////////////////////////////////////////////////////// // // Copyright (c) 2000 The Open Group, BMC Software, Tivoli Systems, IBM // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the "Software"), // to deal in the Software without restriction, including without limitation // the rights to use, copy, modify, merge, publish, distribute, sublicense, // and/or sell copies of the Software, and to permit persons to whom the // Software is furnished to do so, subject to the following conditions: // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER // DEALINGS IN THE SOFTWARE. // //============================================================================== // // Author: Mike Brasher (mbrasher@bmc.com) // // Modified By: // //%///////////////////////////////////////////////////////////////////////////// #ifndef Pegasus_Name_h #define Pegasus_Name_h #include #include #include PEGASUS_NAMESPACE_BEGIN /** The name class defines static methods for handling CIM names. The names of classes, properties, qualifiers, and methods are all CIM names. A CIM name must match the following regular expression:

	[A-Z-a-z_][A-Za-z_0-9]*
    
Notice that the definition of a name is the same as C, C++, and Java. This class cannot be instantiated (since its only constructor is private). */ class PEGASUS_COMMON_LINKAGE CIMName { public: /** CIMMethod legal - Determine if the name string input is legal as defnined in the CIMName class definition ATTN: Define what is legal @param - String to test @return Returns true if the given name is legal. Throws NullPointer exception if name argument is null. */ static Boolean legal(const Char16* name); /** CIMMethod legal - Determine if the name string input is legal as defnined in the CIMName class definition @param - String to test @return Returns true if the given name is legal. Throws NullPointer exception if name argument is null. */ static Boolean legal(const String& name) { return legal(name.getData()); } /** CIMMethod equal - Compares two names. @return Return true if the two names are equal. CIM names are case insensitive and so it this method. */ static Boolean equal(const String& name1, const String& name2) { return String::equalNoCase(name1, name2); } private: CIMName() { } }; PEGASUS_NAMESPACE_END #endif /* Pegasus_Name_h */