(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.1, Tue Jun 12 07:26:01 2001 UTC (23 years ago) by mike
Branch: MAIN
new

//%/////////////////////////////////////////////////////////////////////////////
//
// 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_AssocTable_h
#define Pegasus_AssocTable_h

#include <Pegasus/Common/Config.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).
    */
    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 String& 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 String& assocInstanceName);

    /** Finds all associators of the given object. See 
	CIMOperations::associators() for a full description.
    */
    static Boolean getAssociatorNames(
	const String& path,
	const String& 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 String& objectName,
 	const String& resultClass,
 	const String& role,
	Array<String>& referenceNames);
};

PEGASUS_NAMESPACE_END

#endif /* Pegasus_AssocTable_h */

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2