Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement ToSql trait which displays AST as SQL text format #554

Merged
merged 49 commits into from Jun 6, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
49 commits
Select commit Hold shift + click to select a range
e4560d7
add expr_decoder
bearney74 May 15, 2022
0750bd0
add decoder tests for various expr enums
bearney74 May 16, 2022
ad77579
remove comments
bearney74 May 16, 2022
fd3c7fa
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 16, 2022
73b3019
add Aggregate tests
bearney74 May 16, 2022
d46bbee
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 18, 2022
95dbb3b
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 19, 2022
586ec11
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 22, 2022
36a5b6b
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 25, 2022
e4f87e0
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 26, 2022
8ab5f94
add description column for show indexes command
bearney74 May 26, 2022
cde046c
coverage failed
bearney74 May 26, 2022
273847f
use strum screaming camel case
bearney74 May 26, 2022
19589e9
uppercase CASE, AS and EXTRACT
bearney74 May 26, 2022
fc4d7df
remove necessary Display from enum
bearney74 May 26, 2022
6709b29
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 26, 2022
890e58c
Int to INT
bearney74 May 26, 2022
9e6c413
Merge branch 'ExprDecode' of github.com:earney/gluesql into ExprDecode
bearney74 May 26, 2022
ddba6ef
Int to INT
bearney74 May 26, 2022
f14f6df
Merge branch 'main' into ExprDecode
bearney74 May 28, 2022
768db2b
fix merge issues
bearney74 May 28, 2022
b74ad34
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 29, 2022
dffcf30
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 30, 2022
54ecbe6
add stub statements for expression decoder
bearney74 May 30, 2022
ac0d99a
remove _ => statement
bearney74 May 30, 2022
bc956f4
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 31, 2022
549529a
Merge branch 'gluesql:main' into ExprDecode
bearney74 May 31, 2022
2ca46f0
merge hexstring code
bearney74 May 31, 2022
555abc3
use join function
bearney74 Jun 1, 2022
32cc07f
expr_decode to ToSql
bearney74 Jun 1, 2022
49e8aec
implement ToSql
bearney74 Jun 2, 2022
3b25e6f
move unary and binary operators to use ToSql
bearney74 Jun 2, 2022
4229c93
Merge branch 'gluesql:main' into ExprDecode
bearney74 Jun 2, 2022
58991f4
fmt
bearney74 Jun 2, 2022
056358e
fmt
bearney74 Jun 2, 2022
4bd52cb
fix payload.rs
bearney74 Jun 3, 2022
ed31677
add ToSql module to js
bearney74 Jun 3, 2022
84778f1
make fmt happy
bearney74 Jun 3, 2022
c6fe845
make changes requested by reviewers
bearney74 Jun 3, 2022
8c8bb91
Merge branch 'gluesql:main' into ExprDecode
bearney74 Jun 4, 2022
758509c
make changes requested by reviewers
bearney74 Jun 6, 2022
94e94c6
fix test
bearney74 Jun 6, 2022
dd5da90
make fmt happy
bearney74 Jun 6, 2022
adf2db1
revert show indexes portion of PR
bearney74 Jun 6, 2022
bcbfb7a
add unary/binary op test cases, make code adjustments
bearney74 Jun 6, 2022
382af28
fix module import
bearney74 Jun 6, 2022
6ee365b
Merge branch 'gluesql:main' into ExprDecode
bearney74 Jun 6, 2022
52bbf44
merge with main
bearney74 Jun 6, 2022
043896b
fix nested string; add nested test
bearney74 Jun 6, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
add description column for show indexes command
  • Loading branch information
bearney74 committed May 26, 2022
commit 8ab5f94fe18b165b7425b5732a0a76428df792e6
51 changes: 36 additions & 15 deletions cli/src/print.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use {
comfy_table::{modifiers::UTF8_ROUND_CORNERS, presets::UTF8_BORDERS_ONLY, Row, Table},
gluesql_core::ast::expr_decoder::decode,
gluesql_core::prelude::{Payload, PayloadVariable},
std::io::{Result, Write},
};
Expand Down Expand Up @@ -52,9 +53,13 @@ impl<W: Write> Print<W> {
writeln!(self.output, "{}\n", table)?;
}
Payload::ShowIndexes(indexes) => {
let mut table = get_table(vec!["Index Name", "Order"]);
for (index_name, order) in indexes {
table.add_row([index_name, &order.to_string()]);
let mut table = get_table(vec!["Index Name", "Order", "Description"]);
for index in indexes {
table.add_row([
index.name.to_string(),
index.order.to_string(),
decode(&index.expr),
]);
}
writeln!(self.output, "{}\n", table)?;
}
Expand Down Expand Up @@ -106,7 +111,7 @@ fn get_table<T: Into<Row>>(header: T) -> Table {
#[cfg(test)]
mod tests {
use super::Print;
use gluesql_core::data::SchemaIndexOrd;
use gluesql_core::{data::SchemaIndex, data::SchemaIndexOrd};

#[test]
fn print_help() {
Expand Down Expand Up @@ -136,7 +141,7 @@ mod tests {

#[test]
fn print_payload() {
use gluesql_core::ast::DataType;
use gluesql_core::ast::{BinaryOperator, DataType, Expr};
use gluesql_core::prelude::{Payload, PayloadVariable, Value};

let mut print = Print::new(Vec::new());
Expand Down Expand Up @@ -266,17 +271,33 @@ mod tests {

test!(
"
╭────────────────────╮
│ Index Name Order │
╞════════════════════╡
│ id_ndx ASC │
│ name_ndx DESC │
date_ndx BOTH │
╰────────────────────╯",
╭────────────────────────────────────
│ Index Name Order Description
╞════════════════════════════════════
│ id_ndx ASC id
│ name_ndx DESC name
expr_ndx BOTH expr1 - expr2
╰────────────────────────────────────╯",
&Payload::ShowIndexes(vec![
("id_ndx".to_string(), SchemaIndexOrd::Asc),
("name_ndx".to_string(), SchemaIndexOrd::Desc),
("date_ndx".to_string(), SchemaIndexOrd::Both),
SchemaIndex {
name: "id_ndx".to_string(),
order: SchemaIndexOrd::Asc,
expr: Expr::Identifier("id".to_string())
},
SchemaIndex {
name: "name_ndx".to_string(),
order: SchemaIndexOrd::Desc,
expr: Expr::Identifier("name".to_string())
},
SchemaIndex {
name: "expr_ndx".to_string(),
order: SchemaIndexOrd::Both,
expr: Expr::BinaryOp {
left: Box::new(Expr::Identifier("expr1".to_string())),
op: BinaryOperator::Minus,
right: Box::new(Expr::Identifier("expr2".to_string()))
}
}
],)
);

Expand Down
2 changes: 1 addition & 1 deletion core/src/ast/expr_decoder.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use super::{Aggregate, AstLiteral, CountArgExpr, Expr};

fn decode(expr: &Expr) -> String {
pub fn decode(expr: &Expr) -> String {
match expr {
Expr::Identifier(s) => s.to_string(),
Expr::BinaryOp { left, op, right } => {
Expand Down
3 changes: 2 additions & 1 deletion core/src/ast/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ mod ast_literal;
mod data_type;
mod ddl;
mod expr;
mod expr_decoder;
pub mod expr_decoder;
mod function;
mod operator;
mod query;
Expand All @@ -11,6 +11,7 @@ pub use ast_literal::{AstLiteral, DateTimeField, TrimWhereField};
pub use data_type::DataType;
pub use ddl::*;
pub use expr::Expr;
pub use expr_decoder::*;
pub use function::{Aggregate, CountArgExpr, Function};
pub use operator::*;
pub use query::*;
Expand Down
14 changes: 3 additions & 11 deletions core/src/executor/execute.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use {
},
crate::{
ast::{DataType, SetExpr, Statement, Values},
data::{get_name, Row, Schema, SchemaIndexOrd, Value},
data::{get_name, Row, Schema, SchemaIndex, Value},
executor::limit::Limit,
result::MutResult,
store::{GStore, GStoreMut},
Expand Down Expand Up @@ -65,7 +65,7 @@ pub enum Payload {
#[cfg(feature = "metadata")]
ShowVariable(PayloadVariable),
#[cfg(feature = "index")]
ShowIndexes(Vec<(String, SchemaIndexOrd)>),
ShowIndexes(Vec<SchemaIndex>),
}

#[cfg(feature = "metadata")]
Expand Down Expand Up @@ -347,15 +347,7 @@ pub async fn execute<T, U: GStore<T> + GStoreMut<T>>(
Err(e) => return Err((storage, e)),
};

Ok((
storage,
Payload::ShowIndexes(
indexes
.into_iter()
.map(|index| (index.name, index.order))
.collect(),
),
))
Ok((storage, Payload::ShowIndexes(indexes)))
}
//- Metadata
#[cfg(feature = "metadata")]
Expand Down
27 changes: 23 additions & 4 deletions test-suite/src/index/showindexes.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
use crate::*;

test_case!(showindexes, async move {
use gluesql_core::{data::SchemaIndexOrd, executor::ExecuteError, prelude::Payload};
use gluesql_core::ast::{BinaryOperator, Expr};
use gluesql_core::{
data::SchemaIndex, data::SchemaIndexOrd, executor::ExecuteError, prelude::Payload,
};

run!(
r#"
Expand Down Expand Up @@ -36,9 +39,25 @@ CREATE TABLE Test (

test!(
Ok(Payload::ShowIndexes(vec![
("idx_id".to_string(), SchemaIndexOrd::Both),
("idx_name".to_string(), SchemaIndexOrd::Both),
("idx_id2".to_string(), SchemaIndexOrd::Both)
(SchemaIndex {
name: "idx_id".to_string(),
order: SchemaIndexOrd::Both,
expr: Expr::Identifier("id".to_string())
}),
(SchemaIndex {
name: "idx_name".to_string(),
order: SchemaIndexOrd::Both,
expr: Expr::Identifier("name".to_string())
}),
(SchemaIndex {
name: "idx_id2".to_string(),
order: SchemaIndexOrd::Both,
expr: Expr::BinaryOp {
left: Box::new(Expr::Identifier("id".to_string())),
op: BinaryOperator::Plus,
right: Box::new(Expr::Identifier("num".to_string()))
}
})
])),
"show indexes from Test"
);
Expand Down