(file) Return to AssocTable.h CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Repository

File: [Pegasus] / pegasus / src / Pegasus / Repository / Attic / AssocTable.h (download)
Revision: 1.6, Sun Jul 8 01:37:12 2001 UTC (22 years, 11 months ago) by mike
Branch: MAIN
CVS Tags: TASK-PEP362_RestfulService-merged_out_from_trunk, TASK-PEP348_SCMO-merged_out_from_trunk, TASK-PEP317_pullop-merged_out_from_trunk, TASK-PEP317_pullop-merged_in_to_trunk, TASK-PEP311_WSMan-root, TASK-PEP311_WSMan-branch, RELEASE_2_5_0-RC1, HPUX_TEST, HEAD
Changes since 1.5: +0 -0 lines
FILE REMOVED
bye

//%/////////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 2000, 2001 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 ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN 
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. 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_AssocTable_h
#define Pegasus_AssocTable_h

#include <iostream>
#include <fstream>
#include <Pegasus/Common/Config.h>
#include <Pegasus/Common/CIMReference.h>
#include <Pegasus/Common/String.h>
#include <Pegasus/Common/Array.h>

PEGASUS_NAMESPACE_BEGIN

/** Maintains all associations for a given namesspace.
*/
class PEGASUS_REPOSITORY_LINKAGE AssocTable
{
public:

    /** Appends a row into the association table. There is no checking
	for duplicate entries (the caller ensures this). The case of
	the arguments doesn't matter. They are ignored during comparison.
    */
    static void append(
	PEGASUS_STD(ofstream)& os,
	const String& assocInstanceName,
	const String& assocClassName,
	const String& fromObjectName,
	const String& fromClassName,
	const String& fromPropertyName,
	const String& toObjectName,
	const String& toClassName,
	const String& toPropertyName);

    /** Appends a row into the association table. There is no checking
	for duplicate entries (the caller ensures this). The case of the
	arguments doesn't matter. Case is ignored during comparison.
    */
    static void append(
	const String& path,
	const String& assocInstanceName,
	const String& assocClassName,
	const String& fromObjectName,
	const String& fromClassName,
	const String& fromPropertyName,
	const String& toObjectName,
	const String& toClassName,
	const String& toPropertyName);

    /** Determines whether table contains an assoication entry for the given 
	object (either a class or an instance). This routine compares the 
	objectName parameter with the fromObjectName column.
	@returns true if table contains the given object.
    */
    static Boolean containsObject(
	const String& path,
	const CIMReference& objectName);

    /** Deletes the given association from the table by removing every entry
	with an assocInstanceName equal to the assocInstanceName parameter.
	@returns true if such an association was found.
    */
    static Boolean deleteAssociation(
	const String& path,
	const CIMReference& assocInstanceName);

    /** Finds all associators of the given object. See 
	CIMOperations::associators() for a full description.
    */
    static Boolean getAssociatorNames(
	const String& path,
	const CIMReference& objectName,
        const String& assocClass,
        const String& resultClass,
        const String& role,
        const String& resultRole,
	Array<String>& associatorNames);

    /** Obtain all references (association instance names) in which the
	given object is involved. See CIMOperations::associators() for a 
	full description.
    */
    static Boolean getReferenceNames(
	const String& path,
	const CIMReference& objectName,
 	const String& resultClass,
 	const String& role,
	Array<String>& referenceNames);

private:

    AssocTable() { /* private */ }
};

PEGASUS_NAMESPACE_END

#endif /* Pegasus_AssocTable_h */

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2