Commit 620c58ab authored by Jesse Beder's avatar Jesse Beder
Browse files

Updated the nested RegEx classes so they don't need to also take an std::string

parent d2e03739
...@@ -106,29 +106,25 @@ namespace YAML ...@@ -106,29 +106,25 @@ namespace YAML
// . Returns -1 if no characters were matched (the reason for // . Returns -1 if no characters were matched (the reason for
// not returning zero is that we may have an empty regex // not returning zero is that we may have an empty regex
// which is ALWAYS successful at matching zero characters). // which is ALWAYS successful at matching zero characters).
int RegEx::Match(const std::string& str) const // . REMEMBER that we only match from the start of the buffer!
int RegEx::Match(const Buffer& buffer) const
{ {
if(!m_pOp) if(!m_pOp)
return str.empty() ? 0 : -1; // the empty regex only is successful on the empty string return !buffer ? 0 : -1; // the empty regex only is successful on the empty string
return m_pOp->Match(str, *this); return m_pOp->Match(buffer, *this);
} }
// Match int RegEx::Match(const std::string& str) const
int RegEx::Match(const Stream& in) const
{ {
return Match(in.current()); Buffer buffer(str.c_str(), str.size());
return Match(buffer);
} }
// Match // Match
// . The buffer version does the same thing as the string version; int RegEx::Match(const Stream& in) const
// REMEMBER that we only match from the start of the buffer!
int RegEx::Match(const Buffer& buffer) const
{ {
if(!m_pOp) return Match(in.current());
return !buffer ? 0 : -1; // see above
return m_pOp->Match(buffer, *this);
} }
RegEx operator ! (const RegEx& ex) RegEx operator ! (const RegEx& ex)
...@@ -166,14 +162,6 @@ namespace YAML ...@@ -166,14 +162,6 @@ namespace YAML
// Operators // Operators
// MatchOperator // MatchOperator
int RegEx::MatchOperator::Match(const std::string& str, const RegEx& regex) const
{
if(str.empty() || str[0] != regex.m_a)
return -1;
return 1;
}
int RegEx::MatchOperator::Match(const Buffer& buffer, const RegEx& regex) const int RegEx::MatchOperator::Match(const Buffer& buffer, const RegEx& regex) const
{ {
if(!buffer || buffer[0] != regex.m_a) if(!buffer || buffer[0] != regex.m_a)
...@@ -182,13 +170,6 @@ namespace YAML ...@@ -182,13 +170,6 @@ namespace YAML
} }
// RangeOperator // RangeOperator
int RegEx::RangeOperator::Match(const std::string& str, const RegEx& regex) const
{
if(str.empty() || regex.m_a > str[0] || regex.m_z < str[0])
return -1;
return 1;
}
int RegEx::RangeOperator::Match(const Buffer& buffer, const RegEx& regex) const int RegEx::RangeOperator::Match(const Buffer& buffer, const RegEx& regex) const
{ {
if(!buffer || regex.m_a > buffer[0] || regex.m_z < buffer[0]) if(!buffer || regex.m_a > buffer[0] || regex.m_z < buffer[0])
...@@ -197,16 +178,6 @@ namespace YAML ...@@ -197,16 +178,6 @@ namespace YAML
} }
// OrOperator // OrOperator
int RegEx::OrOperator::Match(const std::string& str, const RegEx& regex) const
{
for(unsigned i=0;i<regex.m_params.size();i++) {
int n = regex.m_params[i].Match(str);
if(n >= 0)
return n;
}
return -1;
}
int RegEx::OrOperator::Match(const Buffer& buffer, const RegEx& regex) const int RegEx::OrOperator::Match(const Buffer& buffer, const RegEx& regex) const
{ {
for(unsigned i=0;i<regex.m_params.size();i++) { for(unsigned i=0;i<regex.m_params.size();i++) {
...@@ -221,19 +192,6 @@ namespace YAML ...@@ -221,19 +192,6 @@ namespace YAML
// Note: 'AND' is a little funny, since we may be required to match things // Note: 'AND' is a little funny, since we may be required to match things
// of different lengths. If we find a match, we return the length of // of different lengths. If we find a match, we return the length of
// the FIRST entry on the list. // the FIRST entry on the list.
int RegEx::AndOperator::Match(const std::string& str, const RegEx& regex) const
{
int first = -1;
for(unsigned i=0;i<regex.m_params.size();i++) {
int n = regex.m_params[i].Match(str);
if(n == -1)
return -1;
if(i == 0)
first = n;
}
return first;
}
int RegEx::AndOperator::Match(const Buffer& buffer, const RegEx& regex) const int RegEx::AndOperator::Match(const Buffer& buffer, const RegEx& regex) const
{ {
int first = -1; int first = -1;
...@@ -248,15 +206,6 @@ namespace YAML ...@@ -248,15 +206,6 @@ namespace YAML
} }
// NotOperator // NotOperator
int RegEx::NotOperator::Match(const std::string& str, const RegEx& regex) const
{
if(regex.m_params.empty())
return -1;
if(regex.m_params[0].Match(str) >= 0)
return -1;
return 1;
}
int RegEx::NotOperator::Match(const Buffer& buffer, const RegEx& regex) const int RegEx::NotOperator::Match(const Buffer& buffer, const RegEx& regex) const
{ {
if(regex.m_params.empty()) if(regex.m_params.empty())
...@@ -267,18 +216,6 @@ namespace YAML ...@@ -267,18 +216,6 @@ namespace YAML
} }
// SeqOperator // SeqOperator
int RegEx::SeqOperator::Match(const std::string& str, const RegEx& regex) const
{
int offset = 0;
for(unsigned i=0;i<regex.m_params.size();i++) {
int n = regex.m_params[i].Match(str.substr(offset));
if(n == -1)
return -1;
offset += n;
}
return offset;
}
int RegEx::SeqOperator::Match(const Buffer& buffer, const RegEx& regex) const int RegEx::SeqOperator::Match(const Buffer& buffer, const RegEx& regex) const
{ {
int offset = 0; int offset = 0;
......
...@@ -19,37 +19,30 @@ namespace YAML ...@@ -19,37 +19,30 @@ namespace YAML
// the operators // the operators
struct Operator { struct Operator {
virtual ~Operator() {} virtual ~Operator() {}
virtual int Match(const std::string& str, const RegEx& regex) const = 0;
virtual int Match(const Buffer& buffer, const RegEx& regex) const = 0; virtual int Match(const Buffer& buffer, const RegEx& regex) const = 0;
}; };
struct MatchOperator: public Operator { struct MatchOperator: public Operator {
virtual int Match(const std::string& str, const RegEx& regex) const;
virtual int Match(const Buffer& buffer, const RegEx& regex) const; virtual int Match(const Buffer& buffer, const RegEx& regex) const;
}; };
struct RangeOperator: public Operator { struct RangeOperator: public Operator {
virtual int Match(const std::string& str, const RegEx& regex) const;
virtual int Match(const Buffer& buffer, const RegEx& regex) const; virtual int Match(const Buffer& buffer, const RegEx& regex) const;
}; };
struct OrOperator: public Operator { struct OrOperator: public Operator {
virtual int Match(const std::string& str, const RegEx& regex) const;
virtual int Match(const Buffer& buffer, const RegEx& regex) const; virtual int Match(const Buffer& buffer, const RegEx& regex) const;
}; };
struct AndOperator: public Operator { struct AndOperator: public Operator {
virtual int Match(const std::string& str, const RegEx& regex) const;
virtual int Match(const Buffer& buffer, const RegEx& regex) const; virtual int Match(const Buffer& buffer, const RegEx& regex) const;
}; };
struct NotOperator: public Operator { struct NotOperator: public Operator {
virtual int Match(const std::string& str, const RegEx& regex) const;
virtual int Match(const Buffer& buffer, const RegEx& regex) const; virtual int Match(const Buffer& buffer, const RegEx& regex) const;
}; };
struct SeqOperator: public Operator { struct SeqOperator: public Operator {
virtual int Match(const std::string& str, const RegEx& regex) const;
virtual int Match(const Buffer& buffer, const RegEx& regex) const; virtual int Match(const Buffer& buffer, const RegEx& regex) const;
}; };
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment