Added namespaces to most classes, general cleanup
Some checks failed
continuous-integration/drone/push Build is failing
Some checks failed
continuous-integration/drone/push Build is failing
This commit is contained in:
@@ -10,122 +10,119 @@
|
||||
#include "../Utilities/HashedString.hpp"
|
||||
|
||||
using namespace std;
|
||||
using namespace Porygon::Utilities;
|
||||
|
||||
class IToken{
|
||||
const unsigned int _position;
|
||||
const unsigned int _length;
|
||||
public:
|
||||
virtual const TokenKind GetKind() const = 0;
|
||||
namespace Porygon::Parser {
|
||||
class IToken {
|
||||
const unsigned int _position;
|
||||
const unsigned int _length;
|
||||
public:
|
||||
virtual const TokenKind GetKind() const = 0;
|
||||
|
||||
IToken(unsigned int position, unsigned int length)
|
||||
: _position(position), _length(length)
|
||||
{
|
||||
}
|
||||
IToken(unsigned int position, unsigned int length)
|
||||
: _position(position), _length(length) {
|
||||
}
|
||||
|
||||
const unsigned int GetStartPosition() const{
|
||||
return _position;
|
||||
}
|
||||
const unsigned int GetStartPosition() const {
|
||||
return _position;
|
||||
}
|
||||
|
||||
const unsigned int GetEndPosition() const{
|
||||
return _position + _length - 1;
|
||||
}
|
||||
const unsigned int GetEndPosition() const {
|
||||
return _position + _length - 1;
|
||||
}
|
||||
|
||||
const unsigned int GetLength() const{
|
||||
return _length;
|
||||
}
|
||||
const unsigned int GetLength() const {
|
||||
return _length;
|
||||
}
|
||||
|
||||
virtual ~IToken() = default;
|
||||
};
|
||||
virtual ~IToken() = default;
|
||||
};
|
||||
|
||||
class SimpleToken : public IToken{
|
||||
const TokenKind _kind;
|
||||
public:
|
||||
class SimpleToken : public IToken {
|
||||
const TokenKind _kind;
|
||||
public:
|
||||
|
||||
explicit SimpleToken(TokenKind kind, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_kind(kind)
|
||||
{
|
||||
}
|
||||
explicit SimpleToken(TokenKind kind, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_kind(kind) {
|
||||
}
|
||||
|
||||
const TokenKind GetKind() const final{
|
||||
return _kind;
|
||||
}
|
||||
};
|
||||
const TokenKind GetKind() const final {
|
||||
return _kind;
|
||||
}
|
||||
};
|
||||
|
||||
class IntegerToken : public IToken{
|
||||
const long _value;
|
||||
public:
|
||||
class IntegerToken : public IToken {
|
||||
const long _value;
|
||||
public:
|
||||
|
||||
explicit IntegerToken(long value, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_value(value)
|
||||
{
|
||||
}
|
||||
explicit IntegerToken(long value, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_value(value) {
|
||||
}
|
||||
|
||||
const TokenKind GetKind() const final{
|
||||
return TokenKind::Integer;
|
||||
}
|
||||
const TokenKind GetKind() const final {
|
||||
return TokenKind::Integer;
|
||||
}
|
||||
|
||||
const long GetValue() const{
|
||||
return _value;
|
||||
}
|
||||
};
|
||||
const long GetValue() const {
|
||||
return _value;
|
||||
}
|
||||
};
|
||||
|
||||
class FloatToken : public IToken{
|
||||
const double _value;
|
||||
public:
|
||||
class FloatToken : public IToken {
|
||||
const double _value;
|
||||
public:
|
||||
|
||||
explicit FloatToken(double value, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_value(value)
|
||||
{
|
||||
}
|
||||
explicit FloatToken(double value, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_value(value) {
|
||||
}
|
||||
|
||||
const TokenKind GetKind() const final{
|
||||
return TokenKind::Float;
|
||||
}
|
||||
const TokenKind GetKind() const final {
|
||||
return TokenKind::Float;
|
||||
}
|
||||
|
||||
const double GetValue() const{
|
||||
return _value;
|
||||
}
|
||||
};
|
||||
const double GetValue() const {
|
||||
return _value;
|
||||
}
|
||||
};
|
||||
|
||||
class StringToken : public IToken{
|
||||
const u16string _value;
|
||||
public:
|
||||
class StringToken : public IToken {
|
||||
const u16string _value;
|
||||
public:
|
||||
|
||||
explicit StringToken(u16string value, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_value(std::move(value))
|
||||
{
|
||||
}
|
||||
explicit StringToken(u16string value, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_value(std::move(value)) {
|
||||
}
|
||||
|
||||
const TokenKind GetKind() const final{
|
||||
return TokenKind::String;
|
||||
}
|
||||
const TokenKind GetKind() const final {
|
||||
return TokenKind::String;
|
||||
}
|
||||
|
||||
const u16string& GetValue() const{
|
||||
return _value;
|
||||
}
|
||||
};
|
||||
const u16string &GetValue() const {
|
||||
return _value;
|
||||
}
|
||||
};
|
||||
|
||||
class IdentifierToken : public IToken{
|
||||
const HashedString _value;
|
||||
public:
|
||||
class IdentifierToken : public IToken {
|
||||
const Utilities::HashedString _value;
|
||||
public:
|
||||
|
||||
explicit IdentifierToken(const HashedString value, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_value(value)
|
||||
{
|
||||
}
|
||||
explicit IdentifierToken(const HashedString value, unsigned int position, unsigned int length)
|
||||
: IToken(position, length),
|
||||
_value(value) {
|
||||
}
|
||||
|
||||
const TokenKind GetKind() const final{
|
||||
return TokenKind::Identifier;
|
||||
}
|
||||
const TokenKind GetKind() const final {
|
||||
return TokenKind::Identifier;
|
||||
}
|
||||
|
||||
const HashedString GetValue() const{
|
||||
return _value;
|
||||
}
|
||||
};
|
||||
const HashedString GetValue() const {
|
||||
return _value;
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
#endif //PORYGONLANG_TOKEN_HPP
|
||||
|
||||
Reference in New Issue
Block a user