Click or drag to resize

DocNodeProxy2ndLevel Class

DocNodeProxy2ndLevel behaves similar to DocNodeProxy, except after deserialization. After deserialization, it does not try to resolve the document itself, but its parent. Only if the document itself is required, it then tries to resolve the document. After the document has been resolved, the behavior is identical to DocNodeProxy.
Inheritance Hierarchy

Namespace: Altaxo.Main
Assembly: AltaxoBase (in AltaxoBase.dll) Version: 4.8.3261.0 (4.8.3261.0)
Syntax
C#
[SerializableAttribute]
public class DocNodeProxy2ndLevel : DocNodeProxy

The DocNodeProxy2ndLevel type exposes the following members.

Constructors
 NameDescription
Protected methodDocNodeProxy2ndLevel(AbsoluteDocumentPath)Initializes a new instance of the DocNodeProxy2ndLevel class
Public methodDocNodeProxy2ndLevel(DocNodeProxy2ndLevel) Cloning constructor.
Public methodDocNodeProxy2ndLevel(IDocumentLeafNode)Initializes a new instance of the DocNodeProxy2ndLevel class
Protected methodDocNodeProxy2ndLevel(IXmlDeserializationInfo) For deserialization purposes only.
Top
Properties
 NameDescription
Protected propertyAccumulatedEventData Gets the accumulated event data.
(Inherited from SuspendableDocumentLeafNodeWithSingleAccumulatedDataT)
Protected propertyDebug_AbsolutePath Gets the absolute path of the node for debugging purposes.
(Inherited from SuspendableDocumentNodeBase)
Protected propertyInternalDocumentNode Gets the internal document node instance, without changing anything and without trying to resolve the path.
(Inherited from DocNodeProxy)
Protected propertyInternalDocumentPath
(Inherited from DocNodeProxy)
Public propertyIsDisposed Gets a value indicating whether this instance is disposed.
(Inherited from SuspendableDocumentNodeBase)
Public propertyIsDisposeInProgress Gets a value indicating whether for this instance dispose is in progress, or the instance is already disposed.
(Inherited from SuspendableDocumentNodeBase)
Public propertyIsEmpty True when both the document and the stored document path are null.
(Inherited from DocNodeProxy)
Public propertyIsSomeoneListeningToChanges Gets a value indicating whether someone is listening to changes. For this, either the ParentObject or the Changed event must be set.
(Inherited from SuspendableDocumentNodeBase)
Public propertyIsSuspended Gets a value indicating whether this instance is suspended.
(Inherited from SuspendableDocumentLeafNode)
Public propertyName Gets the name of this document node. Null is returned if the name is not set or unknown. The set accessor will for most nodes throw a InvalidOperationException, since the name can only be set on IProjectItems.
(Inherited from SuspendableDocumentNodeBase)
Public propertyParentObject Gets/sets the parent object this instance belongs to.
(Inherited from SuspendableDocumentNodeBase)
Top
Methods
 NameDescription
Protected methodAccumulateChangeData
(Inherited from SuspendableDocumentLeafNodeWithEventArgs)
Protected methodAccumulatedChangeData_SetBackAfterResumeAndSuspend Sets the change data without further processing. This function is infrastructure and intended to use only in OnResume after the parent has suspended this node again.
(Inherited from SuspendableDocumentLeafNodeWithSingleAccumulatedDataT)
Protected methodAccumulatedEventData_Clear Clears the accumulated event data.
(Inherited from SuspendableDocumentLeafNodeWithSingleAccumulatedDataT)
Protected methodAccumulatedEventData_HasZeroOrOneEventArg Determines whether there is no or only one single event arg accumulated. If this is the case, the return value is true. If there is one event arg accumulated, it is returned in the argument singleEventArg. The return value is false if there is more than one event arg accumulated. In this case the singleEventArg is null on return, and the calling function should use AccumulatedEventData to enumerate all accumulated event args.
(Inherited from SuspendableDocumentLeafNodeWithSingleAccumulatedDataT)
Protected methodChildDisposeMemberT Helper function to dispose a child node of this instance. It helps to ensure the correct order: first, the child node is set to null and only then the child node is disposed.
(Inherited from SuspendableDocumentNodeBase)
Protected methodClearDocNode Sets the document node to null, but keeps the doc node path.
(Inherited from DocNodeProxy)
Protected methodClearWatch Removes the event handlers for the watch (watch is the object that is the last object that currently exists along the document path).
(Inherited from DocNodeProxy)
Public methodClone
(Overrides DocNodeProxyClone)
Public methodDispose Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
(Inherited from SuspendableDocumentNodeBase)
Protected methodDispose(Boolean) Disposing this instance is special - we must not dispose the reference this instance holds. Instead, we remove all references to the holded document node and also all event handlers-
(Overrides DocNodeProxyDispose(Boolean))
Public methodDocumentObject Returns the document node. If the stored doc node is null, it is tried to resolve the stored document path. If that fails too, null is returned.
(Overrides DocNodeProxyDocumentObject)
Public methodDocumentPath
(Overrides DocNodeProxyDocumentPath)
Public methodEhParentTunnelingEventHappened Is called by the parent when a tunneling event happened into the parent.
(Inherited from SuspendableDocumentNodeBase)
Public methodEhSelfChanged Calls EhSelfChanged with EventArgs.Empty
(Inherited from SuspendableDocumentLeafNodeWithEventArgs)
Protected methodEhSelfChanged(EventArgs) Called if some member of this instance itself has changed.
(Inherited from SuspendableDocumentLeafNode)
Public methodEhSelfTunnelingEventHappened(TunnelingEventArgs) Is called by this instance if a tunneling event happened into this instance. The tunneling event triggers the TunneledEvent and is additionally distributed to all childs of this instance.
(Inherited from SuspendableDocumentNodeBase)
Public methodEhSelfTunnelingEventHappened(TunnelingEventArgs, Boolean) Is called by this instance if a tunneling event happened into this instance. The tunneling event triggers the TunneledEvent and is - depending on the provided parameter - also distributed to all childs of this instance.
(Inherited from SuspendableDocumentNodeBase)
Protected methodEhXmlDeserializationFinished
(Inherited from DocNodeProxy)
Public methodEqualsDetermines whether the specified object is equal to the current object.
(Inherited from Object)
Protected methodFinalize Finalizes an instance of the SuspendableDocumentNodeBase class.
(Inherited from SuspendableDocumentNodeBase)
Public methodGetHashCodeServes as the default hash function.
(Inherited from Object)
Public methodGetTypeGets the Type of the current instance.
(Inherited from Object)
Protected methodHandleLowPriorityChildChangeCases Handles the cases when a child changes, but a reaction is neccessary only if the table is not suspended currently.
(Inherited from SuspendableDocumentLeafNode)
Protected methodInternalCheckAbsolutePath
(Inherited from DocNodeProxy)
Protected methodInternalIsValidDocument
(Overrides DocNodeProxyInternalIsValidDocument(Object, Boolean))
Protected methodInternalSetDocNode Sets the document node that is held by this proxy.
(Inherited from DocNodeProxy)
Protected methodIsValidDocument Can be overriden by derived classes to ensure that the right type of document is stored in this proxy.
(Inherited from DocNodeProxy)
Protected methodMemberwiseCloneCreates a shallow copy of the current Object.
(Inherited from Object)
Protected methodOnAboutToBeResumed Is called when the suspend level is still 1 (one), but is about to fall to zero, i.e. shortly before the call to OnResume. This function is not called before OnResumeSilently!
(Inherited from SuspendableDocumentLeafNode)
Protected methodOnAfterSetDocNode Is called after a document has been set, but before OnChanged() is called. Can be used to set up additional things, like event handlers, in derived classes.
(Inherited from DocNodeProxy)
Protected methodOnBeforeClearDocNode Is called before the doc node of this proxy is set to null. Can be used in derived classes to remove additional event handlers.
(Inherited from DocNodeProxy)
Protected methodOnChanged Fires the change event with the EventArgs provided in the argument.
(Inherited from SuspendableDocumentNodeBase)
Protected methodOnDocNode_Changed Called when the doc node has changed. Can be overwritten in derived classes to implement additional functionality.
(Inherited from DocNodeProxy)
Protected methodOnDocNode_TunnelingEvent Called when the doc node has changed. Can be overwritten in derived classes to implement additional functionality.
(Overrides DocNodeProxyOnDocNode_TunnelingEvent(Object, Object, TunnelingEventArgs))
Protected methodOnResume Is called when the suspend level falls down from 1 to zero by a call to Resume or a call to [M:Altaxo.Main.ISuspendToken.Dispose()].
(Inherited from SuspendableDocumentLeafNode)
Protected methodOnResumeSilently Is called when the suspend level falls down from 1 to zero by a call to ResumeSilently. The implementation should delete any accumulated events, should also disarm the suspendTokens of the childs of this object, and should not fire any Changed events nor set the change state of the object to dirty.
(Inherited from SuspendableDocumentLeafNode)
Protected methodOnSuspended Called when the suspend level has just gone from 0 to 1, i.e. the object was suspended.
(Inherited from SuspendableDocumentLeafNode)
Protected methodOnTunnelingEvent Fires the TunneledEvent event.
(Inherited from SuspendableDocumentNodeBase)
Public methodReplacePathParts Replaces parts of the part of the document node by another part. If the replacement was successful, the original document node is cleared. See ReplacePathParts for details of the part replacement.
(Inherited from DocNodeProxy)
Protected methodResolveDocumentObject Resolves the document object.
(Inherited from DocNodeProxy)
Public methodResume(ISuspendToken) Resumes changed events by calling Resume for the provided suspend token, and setting the reference to the suspend token to null. If Event data were accumulated during the suspended state, a changed event is triggered for each event data.
(Inherited from SuspendableDocumentNodeBase)
Public methodResume(ISuspendToken, EventFiring) Resumes changed events, either with taking the accumulated event data into account (see Resume(ISuspendToken)) or discarding the accumulated event data (see ResumeSilently(ISuspendToken), depending on the provided argument eventFiring.
(Inherited from SuspendableDocumentNodeBase)
Public methodResumeCompleteTemporarily Resumes the object completely for only a short time. Thus, if object was suspended before, it will be suspended again when the function returns.
(Inherited from SuspendableDocumentLeafNode)
Public methodResumeCompleteTemporarilyGetToken Resumes the object completely for the time the returned token is referenced and not disposed. The return value is a token that had 'absorbed' the suspend count of the object, resulting in the suspend count of the object dropped to 0 (zero). When the returned token is finally disposed, the suspend count of the object is increased again by the 'absorbed' suspend count.
(Inherited from SuspendableDocumentLeafNode)
Public methodResumeSilently Resumes changed events by calling Resume for the provided suspend token, and setting the reference to the suspend token to null. All event data accumulated during the suspended state are discarded, and thus no change event is triggered even if the instance has changed during the suspended state.
(Inherited from SuspendableDocumentNodeBase)
Public methodSetDisposeInProgress Sets the flag that dispose is in progress for this node and all child nodes recursively.
(Inherited from SuspendableDocumentNodeBase)
Public methodSetDocNode Sets the document node that is held by this proxy.
(Overrides DocNodeProxySetDocNode(IDocumentLeafNode))
Protected methodSetMemberAndRaiseSelfChangedT(NullableT, NullableT) Sets a member variable of this instance and raise a change event with Empty if the new value is different from the old value. The comparison is done using the IEquatableT interface of the member variable. Note: to set members that implement IDocumentNode please use the Child... functions.
(Inherited from SuspendableDocumentNodeBase)
Protected methodSetMemberAndRaiseSelfChangedT(T, T) Sets a member variable of this instance and raise a change event with Empty if the new value is different from the old value. The comparison is done using the IEquatableT interface of the member variable. Note: to set members that implement IDocumentNode please use the Child... functions.
(Inherited from SuspendableDocumentNodeBase)
Protected methodSetMemberEnumAndRaiseSelfChangedT Sets a member variable (which is an Enum) of this instance and raise a change event with Empty if the new value is different from the old value. The comparison is done using the IEquatableT interface of the member variable. Note: to set members that implement IDocumentNode please use the Child... functions.
(Inherited from SuspendableDocumentNodeBase)
Protected methodSetWatchOnNode Sets the watch on a node that is not our document node, but a node lower in the hierarchy. We watch both the Changed event and the TunneledEvent of this node.
(Inherited from DocNodeProxy)
Public methodSuspendGetToken Suspend will increase the SuspendLevel.
(Inherited from SuspendableDocumentLeafNode)
Public methodToStringReturns a string that represents the current object.
(Inherited from Object)
Public methodTryGetName Test if this item already has a name.
(Inherited from SuspendableDocumentNodeBase)
Top
Events
 NameDescription
Public eventChangedFired when something in the object has changed, and the object is not suspended.
(Inherited from SuspendableDocumentNodeBase)
Public eventTunneledEvent The event that is fired when the object is disposed. First argument is the sender, second argument is the original source, and third argument is the event arg.
(Inherited from SuspendableDocumentNodeBase)
Top
Fields
 NameDescription
Protected field_accumulatedEventData Holds the accumulated change data.
(Inherited from SuspendableDocumentLeafNodeWithSingleAccumulatedDataT)
Protected field_docNodePath The full path to the document node.
(Inherited from DocNodeProxy)
Protected field_docNodeRef The (weak) reference to the document node.
(Inherited from DocNodeProxy)
Protected field_parent The parent object this instance belongs to.
(Inherited from SuspendableDocumentNodeBase)
Protected field_weakDocNodeChangedHandler Holds the (weak) event handler for changed events from the document node.
(Inherited from DocNodeProxy)
Protected field_weakDocNodeTunneledEventHandler Holds the (weak) event handler for tunneling events from the document node.
(Inherited from DocNodeProxy)
Top
Remarks
The behavior mentioned above should ensure that DataColumns held by a DataColumnCollection are resolved by the proxy as late as possible. Only if the DataColumn is required, it then must be loaded from the file system.
See Also