mirror of
https://github.com/zeek/zeek.git
synced 2025-10-02 06:38:20 +00:00
binpac: Initial import of Bro's binpac subdirectory from SVN r7088.
This commit is contained in:
parent
5a1c4fd5fe
commit
c8665318e6
113 changed files with 15630 additions and 0 deletions
112
tools/binpac/lib/binpac_exception.h
Normal file
112
tools/binpac/lib/binpac_exception.h
Normal file
|
@ -0,0 +1,112 @@
|
|||
#ifndef binpac_exception_h
|
||||
#define binpac_exception_h
|
||||
|
||||
namespace binpac {
|
||||
|
||||
class Exception
|
||||
{
|
||||
public:
|
||||
Exception(const char* m = 0)
|
||||
: msg_("binpac exception: ")
|
||||
{
|
||||
if ( m )
|
||||
append(m);
|
||||
// abort();
|
||||
}
|
||||
|
||||
void append(string m) { msg_ += m; }
|
||||
string msg() const { return msg_; }
|
||||
const char* c_msg() const { return msg().c_str(); }
|
||||
|
||||
protected:
|
||||
string msg_;
|
||||
};
|
||||
|
||||
class ExceptionOutOfBound : public Exception
|
||||
{
|
||||
public:
|
||||
ExceptionOutOfBound(const char* where, int len_needed, int len_given)
|
||||
{
|
||||
append(binpac_fmt("out_of_bound: %s: %d > %d",
|
||||
where, len_needed, len_given));
|
||||
}
|
||||
};
|
||||
|
||||
class ExceptionInvalidCase : public Exception
|
||||
{
|
||||
public:
|
||||
ExceptionInvalidCase(const char* location,
|
||||
int index,
|
||||
const char *expected)
|
||||
: location_(location),
|
||||
index_(index),
|
||||
expected_(expected)
|
||||
{
|
||||
append(binpac_fmt("invalid case: %s: %d (%s)",
|
||||
location, index, expected));
|
||||
}
|
||||
|
||||
protected:
|
||||
const char* location_;
|
||||
int index_;
|
||||
string expected_;
|
||||
};
|
||||
|
||||
class ExceptionInvalidCaseIndex : public Exception
|
||||
{
|
||||
public:
|
||||
ExceptionInvalidCaseIndex(const char* location,
|
||||
int index)
|
||||
: location_(location),
|
||||
index_(index)
|
||||
{
|
||||
append(binpac_fmt("invalid index for case: %s: %d",
|
||||
location, index));
|
||||
}
|
||||
|
||||
protected:
|
||||
const char* location_;
|
||||
int index_;
|
||||
};
|
||||
|
||||
class ExceptionInvalidOffset : public Exception
|
||||
{
|
||||
public:
|
||||
ExceptionInvalidOffset(const char* location,
|
||||
int min_offset, int offset)
|
||||
: location_(location),
|
||||
min_offset_(min_offset), offset_(offset)
|
||||
{
|
||||
append(binpac_fmt("invalid offset: %s: min_offset = %d, offset = %d",
|
||||
location, min_offset, offset));
|
||||
}
|
||||
|
||||
protected:
|
||||
const char* location_;
|
||||
int min_offset_, offset_;
|
||||
};
|
||||
|
||||
class ExceptionStringMismatch : public Exception
|
||||
{
|
||||
public:
|
||||
ExceptionStringMismatch(const char* location,
|
||||
const char *expected, const char *actual_data)
|
||||
{
|
||||
append(binpac_fmt("string mismatch at %s: \nexpected pattern: \"%s\"\nactual data: \"%s\"",
|
||||
location, expected, actual_data));
|
||||
}
|
||||
};
|
||||
|
||||
class ExceptionInvalidStringLength : public Exception
|
||||
{
|
||||
public:
|
||||
ExceptionInvalidStringLength(const char* location, int len)
|
||||
{
|
||||
append(binpac_fmt("invalid length string: %s: %d",
|
||||
location, len));
|
||||
}
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
#endif // binpac_exception_h
|
Loading…
Add table
Add a link
Reference in a new issue