Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
att
GitHub Repository: att/ast
Path: blob/master/src/cmd/dsslib/ip_t/ptdifference.c
1810 views
1
/***********************************************************************
2
* *
3
* This software is part of the ast package *
4
* Copyright (c) 2000-2011 AT&T Intellectual Property *
5
* and is licensed under the *
6
* Eclipse Public License, Version 1.0 *
7
* by AT&T Intellectual Property *
8
* *
9
* A copy of the License is available at *
10
* http://www.eclipse.org/org/documents/epl-v10.html *
11
* (with md5 checksum b35adb5213ca9657e911e9befb180842) *
12
* *
13
* Information and Software Systems Research *
14
* AT&T Research *
15
* Florham Park NJ *
16
* *
17
* Glenn Fowler <[email protected]> *
18
* Phong Vo <[email protected]> *
19
* *
20
***********************************************************************/
21
#pragma prototyped
22
23
#include "ptlib.h"
24
25
/*
26
* return the table difference of a and b
27
*/
28
29
Pt_t*
30
ptdifference(Pt_t* a, Pt_t* b)
31
{
32
Pt_t* t;
33
Ptprefix_t* ap;
34
Ptprefix_t* bp;
35
Ptaddr_t m;
36
37
if (!(t = ptopen(a->disc)))
38
return 0;
39
m = 0;
40
ap = (Ptprefix_t*)dtfirst(a->dict);
41
bp = (Ptprefix_t*)dtfirst(b->dict);
42
while (ap)
43
{
44
if (!bp || ap->max < bp->min)
45
{
46
if (!ptinsert(t, ap->min, ap->max))
47
break;
48
ap = (Ptprefix_t*)dtnext(a->dict, ap);
49
}
50
else if (ap->min > bp->max)
51
bp = (Ptprefix_t*)dtnext(b->dict, bp);
52
else
53
{
54
if (ap->min < bp->min && !ptinsert(t, ap->min, bp->min - 1))
55
break;
56
if (ap->max < bp->max)
57
ap = (Ptprefix_t*)dtnext(a->dict, ap);
58
else if (ap->max == bp->max)
59
{
60
ap = (Ptprefix_t*)dtnext(a->dict, ap);
61
bp = (Ptprefix_t*)dtnext(b->dict, bp);
62
}
63
else
64
{
65
while (ap->max > bp->max)
66
{
67
m = bp->max + 1;
68
if (!(bp = (Ptprefix_t*)dtnext(b->dict, bp)) || bp->min > ap->max)
69
{
70
if (!ptinsert(t, m, ap->max))
71
goto done;
72
break;
73
}
74
if (bp->min > m && !ptinsert(t, m, bp->min - 1))
75
goto done;
76
}
77
ap = (Ptprefix_t*)dtnext(a->dict, ap);
78
}
79
}
80
}
81
done:
82
return t;
83
}
84
85