예제 #1
0
        public override bool AltMem <EqA>(A a)
        {
            Fun <A, List <A> > wrap = delegate(A e) { return(new Cons <A>(e, new Nil <A>())); };

            return(Overloads.Eq <EqA, A>(a, h) || t.Map(wrap).Mem <EqList <EqA, A> >(wrap(a)));
            //return Eq(a,h) || t.Map(wrap).Mem(wrap(a));
        }
예제 #2
0
파일: Lists.cs 프로젝트: gtkatakura/roslyn
        public static void Run()
        {
            List <int> l1 = FromArray(1, 2, 3, 4);
            List <int> l2 = FromArray(5, 6, 7, 8);

            Console.WriteLine("Lists: Eq(null,null)={0}", Overloads.Eq <EqList <EqInt, int>, List <int> >(null, null));
            Console.WriteLine("Lists: Eq(null,l1)={0}", Overloads.Eq <EqList <EqInt, int>, List <int> >(null, l1));
            Console.WriteLine("Lists: Eq(l1,null)={0}", Overloads.Eq <EqList <EqInt, int>, List <int> >(l1, null));
            Console.WriteLine("Lists: Eq(l1,l1)={0}", Overloads.Eq <EqList <EqInt, int>, List <int> >(l1, l1));
            Console.WriteLine("Lists: Eq(l1,l2)={0}", Overloads.Eq <EqList <EqInt, int>, List <int> >(l1, l2));
            List <List <int> > ll1 = FromArray(l1, l2);
            List <List <int> > ll2 = FromArray(l2, l1);

            Console.WriteLine("Lists: Eq(null,null)={0}", Overloads.Eq <EqList <EqList <EqInt, int>, List <int> >, List <List <int> > >(null, null));
            Console.WriteLine("Lists: Eq(null,ll1)={0}", Overloads.Eq <EqList <EqList <EqInt, int>, List <int> >, List <List <int> > >(null, ll1));
            Console.WriteLine("Lists: Eq(ll1,null)={0}", Overloads.Eq <EqList <EqList <EqInt, int>, List <int> >, List <List <int> > >(ll1, null));
            Console.WriteLine("Lists: Eq(ll1,ll1)={0}", Overloads.Eq <EqList <EqList <EqInt, int>, List <int> >, List <List <int> > >(ll1, ll1));
            Console.WriteLine("Lists: Eq(ll1,ll2)={0}", Overloads.Eq <EqList <EqList <EqInt, int>, List <int> >, List <List <int> > >(ll1, ll2));
        }
예제 #3
0
파일: Lists.cs 프로젝트: gtkatakura/roslyn
        bool Eq <List <A> > .Equals(List <A> a, List <A> b)
        {
            Nil <A> an = a as Nil <A>;

            if (an != null)
            {
                Nil <A> ab = b as Nil <A>;
                return(b != null);
            }
            ;
            Cons <A> ac = a as Cons <A>;

            if (ac != null)
            {
                Cons <A> bc = b as Cons <A>;
                return(bc != null && Overloads.Eq <EqA, A>(ac.h, bc.h) && Overloads.Eq <EqList <EqA, A>, List <A> >(ac.t, bc.t));
            }
            return(b == null);
        }
예제 #4
0
파일: Lists.cs 프로젝트: gtkatakura/roslyn
 public override bool Mem <EqA>(A a)
 {
     return(Overloads.Eq <EqA, A>(a, h) || t.Mem <EqA>(a));
     //return Eq(a, h) || t.Mem(a);
 }
예제 #5
0
        public override bool Eq <EqA>(List <A> a)
        {
            Cons <A> ca = a as Cons <A>;

            return((a != null) && ca != null && Overloads.Eq <EqA, A>(h, ca.h) && this.t.Eq <EqA>(ca.t));
        }