Compare commits
No commits in common. "ba21718f71d947bb2f491bc39441cfc4e95dd48a" and "43df7efd6fce6766a6e442c7003d324ea89b55eb" have entirely different histories.
ba21718f71
...
43df7efd6f
@ -105,14 +105,8 @@ namespace AST {
|
||||
case types::Unary::SubPrefix:
|
||||
out << "--" << this->m_expr->formatted();
|
||||
break;
|
||||
case types::Unary::Not:
|
||||
out << "!" << this->m_expr->formatted();
|
||||
break;
|
||||
case types::Unary::Negation:
|
||||
out << "-" << this->m_expr->formatted();
|
||||
break;
|
||||
case types::Unary::Plus:
|
||||
out << "+" << this->m_expr->formatted();
|
||||
out << "!" << this->m_expr->formatted();
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
|
||||
@ -167,10 +167,10 @@ namespace types {
|
||||
});
|
||||
}
|
||||
|
||||
// Not & Negation
|
||||
// Negation
|
||||
for (auto& ty : { int_ty, char_ty, bool_ty }) {
|
||||
definitions.push_back(UnopDefinition{
|
||||
ty, types::Unary::Not, ty,
|
||||
ty, types::Unary::Negation, ty,
|
||||
[](codegen::Builder& builder, std::shared_ptr<Type> ty, llvm::Value* value) {
|
||||
codegen::TypeMap structs {};
|
||||
auto llvm_ty = ty->codegen(builder, structs);
|
||||
@ -181,18 +181,6 @@ namespace types {
|
||||
return builder.builder->CreateSelect(cmp, const_1, const_0, "not_select");
|
||||
}
|
||||
});
|
||||
definitions.push_back(UnopDefinition{
|
||||
ty, types::Unary::Negation, ty,
|
||||
[](codegen::Builder& builder, std::shared_ptr<Type>, llvm::Value* value) {
|
||||
return builder.builder->CreateNeg(value, "neg");
|
||||
}
|
||||
});
|
||||
definitions.push_back(UnopDefinition{
|
||||
ty, types::Unary::Plus, ty,
|
||||
[](codegen::Builder&, std::shared_ptr<Type>, llvm::Value* value) {
|
||||
return value;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
return definitions;
|
||||
|
||||
@ -20,9 +20,7 @@ namespace types {
|
||||
AddPrefix,
|
||||
SubPostfix,
|
||||
SubPrefix,
|
||||
Not,
|
||||
Negation,
|
||||
Plus,
|
||||
};
|
||||
|
||||
int operator_precedence(BinOp& op);
|
||||
|
||||
@ -334,14 +334,6 @@ namespace parsing {
|
||||
};
|
||||
}
|
||||
else if (inner.peek().content == "!") {
|
||||
inner.next();
|
||||
auto expr = parse_primary_expression(inner, scope).unwrap();
|
||||
stream.m_position = inner.m_position;
|
||||
return std::unique_ptr<AST::Expression> {
|
||||
new AST::UnaryExpression(before_meta + inner.metadata(), std::move(expr), types::Unary::Not)
|
||||
};
|
||||
}
|
||||
else if (inner.peek().content == "-") {
|
||||
inner.next();
|
||||
auto expr = parse_primary_expression(inner, scope).unwrap();
|
||||
stream.m_position = inner.m_position;
|
||||
@ -349,14 +341,6 @@ namespace parsing {
|
||||
new AST::UnaryExpression(before_meta + inner.metadata(), std::move(expr), types::Unary::Negation)
|
||||
};
|
||||
}
|
||||
else if (inner.peek().content == "+") {
|
||||
inner.next();
|
||||
auto expr = parse_primary_expression(inner, scope).unwrap();
|
||||
stream.m_position = inner.m_position;
|
||||
return std::unique_ptr<AST::Expression> {
|
||||
new AST::UnaryExpression(before_meta + inner.metadata(), std::move(expr), types::Unary::Plus)
|
||||
};
|
||||
}
|
||||
|
||||
auto plain_expr = parse_plain_expression(inner, scope);
|
||||
while (inner.peek().content == "(" || inner.peek().content == "[" || inner.peek().content == ".") {
|
||||
|
||||
Loading…
Reference in New Issue
Block a user