Ejemplo n.º 1
0
        /// <summary>
        /// Adds data to SubGraph and data
        /// </summary>
        /// <param name="item"></param>
        /// <returns></returns>
        public virtual ICollection <TItem> Add(IEnumerable <TItem> elements)
        {
            var worker = new WalkerWorker <TItem, TEdge> (this.Sink);

            foreach (var item in elements)
            {
                if (item is TEdge)
                {
                    if (!Source.Contains((TEdge)item))
                    {
                        Source.Add((TEdge)item);
                    }
                }
                else if (!Source.Contains(item))
                {
                    Source.Add(item);
                }

                worker.Add(item);
            }

            CommitAdd(worker);

            return(worker.Changes);
        }
Ejemplo n.º 2
0
 protected virtual void CommitRemove(WalkerWorker <TItem, TEdge> worker)
 {
     foreach (var item in worker.Changes)
     {
         worker.Graph.Remove(item);
     }
 }
Ejemplo n.º 3
0
        public ICollection <TItem> Collapse(IEnumerable <TItem> elements)
        {
            var worker = new WalkerWorker <TItem, TEdge> (this.Sink);

            NeverRemove(worker, elements);


            foreach (var item in elements)
            {
                worker.RemoveCollapsed(item, this.Sink);
            }

            RevoveEdgesOfChanged(worker);

            CommitRemove(worker);
            var result = worker.Changes;

            if (RemoveOrphans)
            {
                var changes = new List <TItem> (worker.Changes);
                worker.Changes.Clear();
                worker.RemoveOrphans(this.Sink);
                CommitRemove(worker);
                changes.AddRange(worker.Changes);
                worker.Changes.Clear();
                result = changes;
            }

            return(result);
        }
Ejemplo n.º 4
0
        public ICollection <TItem> Hide(IEnumerable <TItem> elements)
        {
            var worker = new WalkerWorker <TItem, TEdge> (this.Sink);

            foreach (var item in elements)
            {
                worker.Remove(item);
                foreach (var edge in this.Sink.Twig(item))
                {
                    worker.Remove(edge);
                }
            }

            RevoveEdgesOfChanged(worker);

            CommitRemove(worker);
            //List<TItem> changes = new List<TItem>(WalkerWorker.Changes);
            //WalkerWorker.Changes.Clear();

            //WalkerWorker.RemoveOrphans(this.View);
            //CommitRemove(WalkerWorker);
            //changes.AddRange(WalkerWorker.Changes);

            //WalkerWorker.Changes.Clear();
            return(worker.Changes);
        }
Ejemplo n.º 5
0
 protected void NeverRemove(WalkerWorker <TItem, TEdge> worker, IEnumerable <TItem> items)
 {
     foreach (var item in items)
     {
         worker.NeverRemove(item);
         worker.Graph.Add(item);
         if (item is TEdge)
         {
             foreach (var edge in worker.Graph.Vein((TEdge)item))
             {
                 worker.NeverRemove(edge);
                 worker.Graph.Add(edge);
                 worker.NeverRemove(edge.Root);
                 worker.Graph.Add(edge.Root);
                 worker.NeverRemove(edge.Leaf);
                 worker.Graph.Add(edge.Leaf);
             }
         }
         else
         {
             foreach (var edge in worker.Graph.Twig(item))
             {
                 if (worker.NoTouch.Contains(edge.Root) &&
                     worker.NoTouch.Contains(edge.Leaf))
                 {
                     worker.NeverRemove(edge);
                     worker.Graph.Add(edge);
                 }
             }
         }
     }
 }
Ejemplo n.º 6
0
        public virtual ICollection <TItem> CollapseToFocused(IEnumerable <TItem> elements)
        {
            var worker = new WalkerWorker <TItem, TEdge> (this.Sink);

            NeverRemove(worker, elements);

            foreach (TItem item in Sink)
            {
                worker.RemoveCollapsed(item, Sink);
                worker.Remove(item);
            }

            CommitRemove(worker);

            return(worker.Changes);
        }
Ejemplo n.º 7
0
        protected virtual void RevoveEdgesOfChanged(WalkerWorker <TItem, TEdge> worker)
        {
            var changeStack = new Stack <TItem> (worker.Changes);

            while (changeStack.Count != 0)
            {
                TItem item = changeStack.Pop();
                if (item is TEdge)
                {
                    TEdge edge = (TEdge)item;
                    if (worker.Changes.Contains(edge.Root) || worker.Changes.Contains(edge.Leaf))
                    {
                        worker.Remove(edge);
                    }
                }
            }
        }
Ejemplo n.º 8
0
        public virtual ICollection <TItem> Expand(IEnumerable <TItem> elements, bool deep)
        {
            var worker = new WalkerWorker <TItem, TEdge> (this.Sink);

            foreach (var item in elements)
            {
                if (deep)
                {
                    worker.AddDeepExpanded(item, this.Source);
                }
                else
                {
                    worker.AddExpanded(item, this.Source);
                }
            }

            CommitAdd(worker);

            return(worker.Changes);
        }
Ejemplo n.º 9
0
        /// <summary>
        /// Adds data to SubGraph and data
        /// </summary>
        /// <param name="item"></param>
        /// <returns></returns>
        public virtual ICollection <TItem> Add(TItem item)
        {
            var worker = new WalkerWorker <TItem, TEdge> (this.Sink);

            if (item is TEdge)
            {
                if (!Source.Contains((TEdge)item))
                {
                    Source.Add((TEdge)item);
                }
            }
            else if (!Source.Contains(item))
            {
                Source.Add(item);
            }

            worker.Add(item);

            CommitAdd(worker);

            return(worker.Changes);
        }
Ejemplo n.º 10
0
        /// <summary>
        /// add all items of worker into SubGraph
        /// add invisible, but valid edges into SubGraph:
        /// </summary>
        /// <param name="worker"></param>
        protected virtual void CommitAdd(WalkerWorker <TItem, TEdge> worker)
        {
            var changeStack = new Stack <TItem> (worker.Changes);

            while (changeStack.Count > 0)
            {
                var item = changeStack.Pop();

                Sink.Add(item);

                // look if we have invisible, but valid edges
                var sink = Source as ISinkGraph <TItem, TEdge>;
                if (sink != null)
                {
                    foreach (var edge in sink.ComplementEdges(item, Sink))
                    {
                        if (!worker.Changes.Contains(edge))
                        {
                            changeStack.Push(edge);
                            worker.Changes.Add(edge);
                        }
                    }
                }
                else
                {
                    foreach (var edge in Source.Fork(item))
                    {
                        if (worker.Contains(edge.Root) && worker.Contains(edge.Leaf))
                        {
                            if (!worker.Changes.Contains(edge))
                            {
                                changeStack.Push(edge);
                                worker.Changes.Add(edge);
                            }
                        }
                    }
                }
            }
        }