blob: 2e673698e9cbe41c4ba4d79476de4cd7e1628d5f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
/********************* */
/*! \file regexp.cpp
** \verbatim
** Top contributors (to current version):
** Andrew Reynolds
** This file is part of the CVC4 project.
** Copyright (c) 2009-2020 by the authors listed in the file AUTHORS
** in the top-level source directory and their institutional affiliations.
** All rights reserved. See the file COPYING in the top-level source
** directory for licensing information.\endverbatim
**
** \brief Implementation of data structures for regular expression operators.
**/
#include "util/regexp.h"
#include <ostream>
namespace CVC4 {
RegExpRepeat::RegExpRepeat(uint32_t repeatAmount) : d_repeatAmount(repeatAmount)
{
}
bool RegExpRepeat::operator==(const RegExpRepeat& r) const
{
return d_repeatAmount == r.d_repeatAmount;
}
RegExpLoop::RegExpLoop(uint32_t l, uint32_t h)
: d_loopMinOcc(l), d_loopMaxOcc(h)
{
}
bool RegExpLoop::operator==(const RegExpLoop& r) const
{
return d_loopMinOcc == r.d_loopMinOcc && d_loopMaxOcc == r.d_loopMaxOcc;
}
size_t RegExpRepeatHashFunction::operator()(const RegExpRepeat& r) const
{
return r.d_repeatAmount;
}
size_t RegExpLoopHashFunction::operator()(const RegExpLoop& r) const
{
return r.d_loopMinOcc + r.d_loopMaxOcc;
}
std::ostream& operator<<(std::ostream& os, const RegExpRepeat& r)
{
return os << r.d_repeatAmount;
}
std::ostream& operator<<(std::ostream& os, const RegExpLoop& r)
{
return os << "[" << r.d_loopMinOcc << ".." << r.d_loopMaxOcc << "]";
}
} // namespace CVC4
|