Merge remote-tracking branch 'upstream/master' into Issue-124-handle-async-for-GET_AITER_GET_ANEXT
Conflicts: ASTree.cpp
This commit is contained in:
58
ASTNode.h
58
ASTNode.h
@@ -15,6 +15,7 @@ public:
|
||||
NODE_TUPLE, NODE_LIST, NODE_MAP, NODE_SUBSCR, NODE_PRINT,
|
||||
NODE_CONVERT, NODE_KEYWORD, NODE_RAISE, NODE_EXEC, NODE_BLOCK,
|
||||
NODE_COMPREHENSION, NODE_LOADBUILDCLASS, NODE_AWAITABLE,
|
||||
NODE_FORMATTEDVALUE, NODE_JOINEDSTR, NODE_CONST_MAP,
|
||||
|
||||
// Empty node types
|
||||
NODE_LOCALS,
|
||||
@@ -358,6 +359,21 @@ private:
|
||||
map_t m_values;
|
||||
};
|
||||
|
||||
class ASTConstMap : public ASTNode {
|
||||
public:
|
||||
typedef std::vector<PycRef<ASTNode>> values_t;
|
||||
|
||||
ASTConstMap(PycRef<ASTNode> keys, const values_t& values)
|
||||
: ASTNode(NODE_CONST_MAP), m_keys(std::move(keys)), m_values(std::move(values)) { }
|
||||
|
||||
const PycRef<ASTNode>& keys() const { return m_keys; }
|
||||
const values_t& values() const { return m_values; }
|
||||
|
||||
private:
|
||||
PycRef<ASTNode> m_keys;
|
||||
values_t m_values;
|
||||
};
|
||||
|
||||
|
||||
class ASTSubscr : public ASTNode {
|
||||
public:
|
||||
@@ -611,4 +627,46 @@ private:
|
||||
PycRef<ASTNode> m_expr;
|
||||
};
|
||||
|
||||
class ASTFormattedValue : public ASTNode {
|
||||
public:
|
||||
enum ConversionFlag {
|
||||
NONE = 0,
|
||||
STR = 1,
|
||||
REPR = 2,
|
||||
ASCII = 3,
|
||||
FMTSPEC = 4
|
||||
};
|
||||
|
||||
ASTFormattedValue(PycRef<ASTNode> val, ConversionFlag conversion,
|
||||
PycRef<ASTNode> format_spec)
|
||||
: ASTNode(NODE_FORMATTEDVALUE),
|
||||
m_val(std::move(val)),
|
||||
m_conversion(conversion),
|
||||
m_format_spec(std::move(format_spec))
|
||||
{ }
|
||||
|
||||
PycRef<ASTNode> val() const { return m_val; }
|
||||
ConversionFlag conversion() const { return m_conversion; }
|
||||
PycRef<ASTNode> format_spec() const { return m_format_spec; }
|
||||
|
||||
private:
|
||||
PycRef<ASTNode> m_val;
|
||||
ConversionFlag m_conversion;
|
||||
PycRef<ASTNode> m_format_spec;
|
||||
};
|
||||
|
||||
// Same as ASTList
|
||||
class ASTJoinedStr : public ASTNode {
|
||||
public:
|
||||
typedef std::list<PycRef<ASTNode>> value_t;
|
||||
|
||||
ASTJoinedStr(value_t values)
|
||||
: ASTNode(NODE_JOINEDSTR), m_values(std::move(values)) { }
|
||||
|
||||
const value_t& values() const { return m_values; }
|
||||
|
||||
private:
|
||||
value_t m_values;
|
||||
};
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user