Esempio n. 1
0
        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();
        }
Esempio n. 2
0
        /// <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);
        }
Esempio n. 3
0
 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);
 }
Esempio n. 4
0
 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);
 }
Esempio n. 5
0
        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);
        }
Esempio n. 6
0
        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);
        }
Esempio n. 7
0
 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());
 }
Esempio n. 8
0
 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));
 }
Esempio n. 9
0
 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]);
     }
 }