MonikerCommonPrefixWith  _SK0I7

Creates a new moniker based on the common prefix that this moniker (the one comprising the data of this moniker object) shares with another moniker. This function is intended to be called only in implementations of IMoniker::CommonPrefixWithK6I29R.

WINOLEAPI MonikerCommonPrefixWith(

    LPMONIKER pmkThis,

//Pointer to the first moniker being compared

    LPMONIKER pmkOther,

//Pointer to the second moniker being compared

    LPMONIKER FAR *ppmkCommon

//Indirect pointer to a moniker

   );

 

 

Parameters

pmkThis

[in] Pointer to the IMoniker interface on one of the monikers for which a common prefix is sought; usually the moniker in which this call is used to implement IMoniker::CommonPrefixWith.

pmkOther

[in] Pointer to the IMoniker interface on the other moniker to compare with the first moniker.

ppmkCommon

[out] When successful, indirect pointer to an IMoniker interface on a moniker based on the common prefix of pmkThis and pmkOther. In this case, the function has called IUnknown::AddRef1SHW0SS on the parameter and the caller is responsible for calling IUnknown::ReleaseDUW01A. If an error occurs, the supplied pointer value is NULL if an error occurs.

 

Return Values

This function supports the standard return values E_OUTOFMEMORY and E_UNEXPECTED, as well as the following:

S_OK

A common prefix exists that is neither pmkThis nor pmkOther.

MK_S_HIM

The entire pmkOther moniker is a prefix of the pmkThis moniker.

MK_S_ME

The entire pmkThis moniker is a prefix of the pmkOther moniker.

MK_S_US

The pmkThis and pmkOther monikers are equal.

MK_E_NOPREFIX

The monikers have no common prefix.

MK_E_NOTBINDABLE

This function was called on a relative moniker. It is not meaningful to take the common prefix of relative monikers.

 

Remarks

Call MonikerCommonPrefixWith only in the implementation of IMoniker::CommonPrefixWithK6I29R for a new moniker class.

Your implementation of IMoniker::CommonPrefixWith should first check whether the other moniker is of a type that you recognize and handle in a special way. If not, you should call MonikerCommonPrefixWith, passing itself as pmkThis and the other moniker as pmkOther. MonikerCommonPrefixWith correctly handles the cases where either moniker is a generic composite.

You should call this function only if pmkThis and pmkOther are both absolute monikers (where an absolute moniker is either a file moniker or a generic composite whose leftmost component is a file moniker, and where the file moniker represents an absolute path). Do not call this function on relative monikers.

See Also

IMoniker::CommonPrefixWith