From b938fda24fda546715b919aa7b37d6c0cf540041 Mon Sep 17 00:00:00 2001 From: Alan Cai Date: Fri, 8 Mar 2024 17:01:23 -0800 Subject: [PATCH] Fixes `SqlDialect` output for unary ops (#1384) --- CHANGELOG.md | 1 + .../kotlin/org/partiql/ast/sql/SqlDialect.kt | 10 +++-- .../org/partiql/ast/sql/SqlDialectTest.kt | 45 +++++++++++++++++-- 3 files changed, 49 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 28803d07d..411def065 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -36,6 +36,7 @@ Thank you to all who have contributed! ### Deprecated ### Fixed +- partiql-ast: `SqlDialect` will wrap unary ops (`NOT`, `+`, `-`) in parens ### Removed diff --git a/partiql-ast/src/main/kotlin/org/partiql/ast/sql/SqlDialect.kt b/partiql-ast/src/main/kotlin/org/partiql/ast/sql/SqlDialect.kt index bb77efa4c..02847e700 100644 --- a/partiql-ast/src/main/kotlin/org/partiql/ast/sql/SqlDialect.kt +++ b/partiql-ast/src/main/kotlin/org/partiql/ast/sql/SqlDialect.kt @@ -230,13 +230,15 @@ public abstract class SqlDialect : AstBaseVisitor() { override fun visitExprUnary(node: Expr.Unary, head: SqlBlock): SqlBlock { val op = when (node.op) { - Expr.Unary.Op.NOT -> "NOT " - Expr.Unary.Op.POS -> "+" - Expr.Unary.Op.NEG -> "-" + Expr.Unary.Op.NOT -> "NOT (" + Expr.Unary.Op.POS -> "+(" + Expr.Unary.Op.NEG -> "-(" } var h = head h = h concat r(op) - return visitExprWrapped(node.expr, h) + h = visitExprWrapped(node.expr, h) + h = h concat r(")") + return h } override fun visitExprBinary(node: Expr.Binary, head: SqlBlock): SqlBlock { diff --git a/partiql-ast/src/test/kotlin/org/partiql/ast/sql/SqlDialectTest.kt b/partiql-ast/src/test/kotlin/org/partiql/ast/sql/SqlDialectTest.kt index 28b161bef..039fbd411 100644 --- a/partiql-ast/src/test/kotlin/org/partiql/ast/sql/SqlDialectTest.kt +++ b/partiql-ast/src/test/kotlin/org/partiql/ast/sql/SqlDialectTest.kt @@ -227,24 +227,63 @@ class SqlDialectTest { @JvmStatic fun exprOperators() = listOf( - expect("NOT NULL") { + expect("NOT (NULL)") { exprUnary { op = Expr.Unary.Op.NOT expr = NULL } }, - expect("+NULL") { + expect("+(NULL)") { exprUnary { op = Expr.Unary.Op.POS expr = NULL } }, - expect("-NULL") { + expect("-(NULL)") { exprUnary { op = Expr.Unary.Op.NEG expr = NULL } }, + expect("NOT (NOT (NULL))") { + exprUnary { + op = Expr.Unary.Op.NOT + expr = exprUnary { + op = Expr.Unary.Op.NOT + expr = NULL + } + } + }, + expect("+(+(NULL))") { + exprUnary { + op = Expr.Unary.Op.POS + expr = exprUnary { + op = Expr.Unary.Op.POS + expr = NULL + } + } + }, + expect("-(-(NULL))") { + exprUnary { + op = Expr.Unary.Op.NEG + expr = exprUnary { + op = Expr.Unary.Op.NEG + expr = NULL + } + } + }, + expect("+(-(+(NULL)))") { + exprUnary { + op = Expr.Unary.Op.POS + expr = exprUnary { + op = Expr.Unary.Op.NEG + expr = exprUnary { + op = Expr.Unary.Op.POS + expr = NULL + } + } + } + }, expect("NULL + NULL") { exprBinary { op = Expr.Binary.Op.PLUS