Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
att
GitHub Repository: att/ast
Path: blob/master/src/cmd/dsslib/ip_t/ptcover.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 cover of a over b
27
* the ranges in a that intersect with b
28
*/
29
30
Pt_t*
31
ptcover(Pt_t* a, Pt_t* b)
32
{
33
Pt_t* t;
34
Ptprefix_t* ap;
35
Ptprefix_t* bp;
36
37
if (!(t = ptopen(a->disc)))
38
return 0;
39
ap = (Ptprefix_t*)dtfirst(a->dict);
40
bp = (Ptprefix_t*)dtfirst(b->dict);
41
while (ap && bp)
42
{
43
if (ap->min > bp->max)
44
bp = (Ptprefix_t*)dtnext(b->dict, bp);
45
else
46
{
47
if (ap->max >= bp->min && !ptinsert(t, ap->min, ap->max))
48
break;
49
ap = (Ptprefix_t*)dtnext(a->dict, ap);
50
}
51
}
52
return t;
53
}
54
55