public static DslModeling::ElementLink Connect(DslModeling::ModelElement source, DslModeling::ModelElement target) { if (source == null) { throw new global::System.ArgumentNullException("source"); } if (target == null) { throw new global::System.ArgumentNullException("target"); } if (CanAcceptSourceAndTarget(source, target)) { if (source is global::BotFrameworkDsl.Node) { if (target is global::BotFrameworkDsl.Node) { global::BotFrameworkDsl.Node sourceAccepted = (global::BotFrameworkDsl.Node)source; global::BotFrameworkDsl.Node targetAccepted = (global::BotFrameworkDsl.Node)target; DslModeling::ElementLink result = new global::BotFrameworkDsl.NodeReferencesTargets(sourceAccepted, targetAccepted); if (DslModeling::DomainClassInfo.HasNameProperty(result)) { DslModeling::DomainClassInfo.SetUniqueName(result); } return(result); } } } global::System.Diagnostics.Debug.Fail("Having agreed that the connection can be accepted we should never fail to make one."); throw new global::System.InvalidOperationException(); }
/// <summary> /// Called by the Merge process to create a relationship between /// this target element and the specified source element. /// Typically, a parent-child relationship is established /// between the target element (the parent) and the source element /// (the child), but any relationship can be established. /// </summary> /// <param name="sourceElement">The element that is to be related to this model element.</param> /// <param name="elementGroup">The group of source ModelElements that have been rehydrated into the target store.</param> /// <remarks> /// This method is overriden to create the relationship between the target element and the specified source element. /// The base method does nothing. /// </remarks> protected override void MergeRelate(DslModeling::ModelElement sourceElement, DslModeling::ElementGroup elementGroup) { // In general, sourceElement is allowed to be null, meaning that the elementGroup must be parsed for special cases. // However this is not supported in generated code. Use double-deriving on this class and then override MergeRelate completely if you // need to support this case. if (sourceElement == null) { throw new global::System.ArgumentNullException("sourceElement"); } global::BotFrameworkDsl.Node sourceNode1 = sourceElement as global::BotFrameworkDsl.Node; if (sourceNode1 != null) { // Create link for path BotFrameworkModelHasElements.Elements this.Elements.Add(sourceNode1); return; } // Sdk workaround to runtime bug #879350 (DSL: can't copy and paste a MEL that has a MEX). Avoid MergeRelate on ModelElementExtension // during a "Paste". if (sourceElement is DslModeling::ExtensionElement && sourceElement.Store.TransactionManager.CurrentTransaction.TopLevelTransaction.Context.ContextInfo.ContainsKey("{9DAFD42A-DC0E-4d78-8C3F-8266B2CF8B33}")) { return; } // Fall through to base class if this class hasn't handled the merge. base.MergeRelate(sourceElement, elementGroup); }
public static global::BotFrameworkDsl.BotFrameworkModel GetParentForListen(global::BotFrameworkDsl.Node root) { // Segments 0 and 1 global::BotFrameworkDsl.BotFrameworkModel result = root.BotFrameworkModel; if (result == null) { return(null); } return(result); }
public static global::BotFrameworkDsl.NodeReferencesTargets GetLink(global::BotFrameworkDsl.Node source, global::BotFrameworkDsl.Node target) { global::System.Collections.Generic.IList <global::BotFrameworkDsl.NodeReferencesTargets> links = DslModeling::DomainRoleInfo.GetElementLinks <global::BotFrameworkDsl.NodeReferencesTargets>(source, global::BotFrameworkDsl.NodeReferencesTargets.SourceDomainRoleId); foreach (global::BotFrameworkDsl.NodeReferencesTargets link in links) { if (target.Equals(link.Target)) { return(link); } } return(null); }
public static bool CanAcceptSourceAndTarget(DslModeling::ModelElement candidateSource, DslModeling::ModelElement candidateTarget) { // Accepts null, null; source, null; source, target but NOT null, target if (candidateSource == null) { if (candidateTarget != null) { throw new global::System.ArgumentNullException("candidateSource"); } else // Both null { return(false); } } bool acceptSource = CanAcceptSource(candidateSource); // If the source wasn't accepted then there's no point checking targets. // If there is no target then the source controls the accept. if (!acceptSource || candidateTarget == null) { return(acceptSource); } else // Check combinations { if (candidateSource is global::BotFrameworkDsl.Node) { if (candidateTarget is global::BotFrameworkDsl.Node) { global::BotFrameworkDsl.Node sourceNode = (global::BotFrameworkDsl.Node)candidateSource; global::BotFrameworkDsl.Node targetNode = (global::BotFrameworkDsl.Node)candidateTarget; if (targetNode == null || sourceNode == null || global::BotFrameworkDsl.NodeReferencesTargets.GetLinks(sourceNode, targetNode).Count > 0) { return(false); } return(true); } } } return(false); }
protected override void MergeDisconnect(DslModeling::ModelElement sourceElement) { if (sourceElement == null) { throw new global::System.ArgumentNullException("sourceElement"); } global::BotFrameworkDsl.Node sourceNode1 = sourceElement as global::BotFrameworkDsl.Node; if (sourceNode1 != null) { // Delete link for path BotFrameworkModelHasElements.Elements foreach (DslModeling::ElementLink link in global::BotFrameworkDsl.BotFrameworkModelHasElements.GetLinks((global::BotFrameworkDsl.BotFrameworkModel) this, sourceNode1)) { // Delete the link, but without possible delete propagation to the element since it's moving to a new location. link.Delete(global::BotFrameworkDsl.BotFrameworkModelHasElements.BotFrameworkModelDomainRoleId, global::BotFrameworkDsl.BotFrameworkModelHasElements.ElementDomainRoleId); } return; } // Fall through to base class if this class hasn't handled the unmerge. base.MergeDisconnect(sourceElement); }
public static global::System.Collections.ObjectModel.ReadOnlyCollection <global::BotFrameworkDsl.NodeReferencesTargets> GetLinks(global::BotFrameworkDsl.Node source, global::BotFrameworkDsl.Node target) { global::System.Collections.Generic.List <global::BotFrameworkDsl.NodeReferencesTargets> outLinks = new global::System.Collections.Generic.List <global::BotFrameworkDsl.NodeReferencesTargets>(); global::System.Collections.Generic.IList <global::BotFrameworkDsl.NodeReferencesTargets> links = DslModeling::DomainRoleInfo.GetElementLinks <global::BotFrameworkDsl.NodeReferencesTargets>(source, global::BotFrameworkDsl.NodeReferencesTargets.SourceDomainRoleId); foreach (global::BotFrameworkDsl.NodeReferencesTargets link in links) { if (target.Equals(link.Target)) { outLinks.Add(link); } } return(outLinks.AsReadOnly()); }
public static global::System.Collections.ObjectModel.ReadOnlyCollection <global::BotFrameworkDsl.NodeReferencesTargets> GetLinksToSources(global::BotFrameworkDsl.Node targetInstance) { return(DslModeling::DomainRoleInfo.GetElementLinks <global::BotFrameworkDsl.NodeReferencesTargets>(targetInstance, global::BotFrameworkDsl.NodeReferencesTargets.TargetDomainRoleId)); }
public static global::BotFrameworkDsl.BotFrameworkModelHasElements GetLinkToBotFrameworkModel(global::BotFrameworkDsl.Node elementInstance) { global::System.Collections.Generic.IList <global::BotFrameworkDsl.BotFrameworkModelHasElements> links = DslModeling::DomainRoleInfo.GetElementLinks <global::BotFrameworkDsl.BotFrameworkModelHasElements>(elementInstance, global::BotFrameworkDsl.BotFrameworkModelHasElements.ElementDomainRoleId); global::System.Diagnostics.Debug.Assert(links.Count <= 1, "Multiplicity of Element not obeyed."); if (links.Count == 0) { return(null); } else { return(links[0]); } }