Skip to main content

%Library.GUID

Class %Library.GUID [ Abstract, System = 3 ]

For information on this class, see Using Object Synchronization.

This class implements utility methods for GUIDs.

Parameters

GUIDENABLED

Parameter GUIDENABLED = 1;

Methods

Filter

ClassMethod Filter(guid As %String, FilterObject As %RegisteredObject = "", trn As %Integer) As %Integer

This method should be implemented by the user. This method is invoked by %SYNC.SyncSet.AddJournaledObject when the Filter is not null. Non zero return value means that the object should be excluded

%GUIDFind

ClassMethod %GUIDFind(guid As %String) As %RawString [ CodeMode = expression ]

%GUIDGetNextOp

ClassMethod %GUIDGetNextOp(guid As %String, ByRef num As %String) As %RawString

%GUIDGetLastOp

ClassMethod %GUIDGetLastOp(guid As %String, ByRef num As %String) As %RawString

AssignGUID

ClassMethod AssignGUID(class As %String, nOutput As %Integer = 0) As %Status

This method will assign a GUID to all objects that don't already have one.

%FindGUID

ClassMethod %FindGUID(pClassName As %String(MAXLEN=""), pID As %Binary) As %String

%FindGUID() attempts to locate the GUID of object for which we do not know the most specific type class. This can happen when resolving the ID for an object that has been deleted, as sometimes occurs when dealing with objects retrieved from the system journal for the purpose of synchronizing with another system. This method assumes that the normal GUID resolution has failed and that if another object of a different MSTC exists within the same root extent then it is the same object (same GUID). For example, class A is persistent and it has two sub classes - B and C. An instance of B is created and assigned a GUID. At some future time, that instance of B is deleted and recreated as an instance of C using the same ID value. The premise of %FindGUID is that the object having an OID of (id,"B") is the same object as that with an OID of (id,"C").