ast: SqlExpr
parent
2daf915371
commit
e8f8defc3e
|
@ -1,6 +1,7 @@
|
||||||
import os
|
import os
|
||||||
import pg
|
import pg
|
||||||
import term
|
import term
|
||||||
|
import sqlite
|
||||||
|
|
||||||
struct Modules {
|
struct Modules {
|
||||||
id int
|
id int
|
||||||
|
@ -10,7 +11,30 @@ struct Modules {
|
||||||
//nr_downloads int
|
//nr_downloads int
|
||||||
}
|
}
|
||||||
|
|
||||||
fn test_orm() {
|
fn test_orm_sqlite() {
|
||||||
|
db := sqlite.connect(':memory:') or { panic(err) }
|
||||||
|
/*
|
||||||
|
db.exec("drop table if exists users")
|
||||||
|
db.exec("create table users (id integer primary key, name text default '');")
|
||||||
|
|
||||||
|
db.exec("insert into users (name) values ('Sam')")
|
||||||
|
db.exec("insert into users (name) values ('Peter')")
|
||||||
|
db.exec("insert into users (name) values ('Kate')")
|
||||||
|
nr_users := sql db {
|
||||||
|
//select count from modules
|
||||||
|
}
|
||||||
|
assert nr_users == 3
|
||||||
|
println('nr_users=')
|
||||||
|
println(nr_users)
|
||||||
|
//nr_modules := db.select count from modules
|
||||||
|
//nr_modules := db.select count from Modules where id == 1
|
||||||
|
//nr_modules := db.select count from Modules where
|
||||||
|
//name == 'Bob' && id == 1
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
fn test_orm_pg() {
|
||||||
dbname := os.getenv('VDB_NAME')
|
dbname := os.getenv('VDB_NAME')
|
||||||
dbuser := os.getenv('VDB_USER')
|
dbuser := os.getenv('VDB_USER')
|
||||||
if dbname == '' || dbuser == '' {
|
if dbname == '' || dbuser == '' {
|
||||||
|
@ -18,6 +42,7 @@ fn test_orm() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
db := pg.connect(dbname: dbname, user: dbuser) or { panic(err) }
|
db := pg.connect(dbname: dbname, user: dbuser) or { panic(err) }
|
||||||
|
_ = db
|
||||||
/*
|
/*
|
||||||
//nr_modules := db.select count from modules
|
//nr_modules := db.select count from modules
|
||||||
//nr_modules := db.select count from Modules where id == 1
|
//nr_modules := db.select count from Modules where id == 1
|
||||||
|
|
|
@ -27,9 +27,11 @@ fn C.sqlite3_finalize()
|
||||||
fn C.sqlite3_column_count(voidptr) int
|
fn C.sqlite3_column_count(voidptr) int
|
||||||
|
|
||||||
// Opens the connection with a database.
|
// Opens the connection with a database.
|
||||||
pub fn connect(path string) DB {
|
pub fn connect(path string) ?DB {
|
||||||
db := &C.sqlite3(0)
|
db := &C.sqlite3(0)
|
||||||
C.sqlite3_open(path.str, &db)
|
if C.sqlite3_open(path.str, &db) != 0 {
|
||||||
|
return error('sqlite db error')
|
||||||
|
}
|
||||||
return DB{
|
return DB{
|
||||||
conn: db
|
conn: db
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,9 +11,9 @@ pub type TypeDecl = AliasTypeDecl | FnTypeDecl | SumTypeDecl
|
||||||
|
|
||||||
pub type Expr = AnonFn | ArrayInit | AsCast | AssignExpr | Assoc | BoolLiteral | CallExpr |
|
pub type Expr = AnonFn | ArrayInit | AsCast | AssignExpr | Assoc | BoolLiteral | CallExpr |
|
||||||
CastExpr | CharLiteral | ComptimeCall | ConcatExpr | EnumVal | FloatLiteral | Ident | IfExpr |
|
CastExpr | CharLiteral | ComptimeCall | ConcatExpr | EnumVal | FloatLiteral | Ident | IfExpr |
|
||||||
IfGuardExpr | IndexExpr | InfixExpr | IntegerLiteral | MapInit | MatchExpr | None | OrExpr |
|
IfGuardExpr | IndexExpr | InfixExpr | IntegerLiteral | Likely | MapInit | MatchExpr | None |
|
||||||
ParExpr | PostfixExpr | PrefixExpr | RangeExpr | SelectorExpr | SizeOf | StringInterLiteral |
|
OrExpr | ParExpr | PostfixExpr | PrefixExpr | RangeExpr | SelectorExpr | SizeOf | SqlExpr |
|
||||||
StringLiteral | StructInit | Type | TypeOf | Likely
|
StringInterLiteral | StringLiteral | StructInit | Type | TypeOf
|
||||||
|
|
||||||
pub type Stmt = AssertStmt | AssignStmt | Attr | Block | BranchStmt | Comment | CompIf | ConstDecl |
|
pub type Stmt = AssertStmt | AssignStmt | Attr | Block | BranchStmt | Comment | CompIf | ConstDecl |
|
||||||
DeferStmt | EnumDecl | ExprStmt | FnDecl | ForCStmt | ForInStmt | ForStmt | GlobalDecl | GoStmt |
|
DeferStmt | EnumDecl | ExprStmt | FnDecl | ForCStmt | ForInStmt | ForStmt | GlobalDecl | GoStmt |
|
||||||
|
@ -796,7 +796,6 @@ pub:
|
||||||
method_name string
|
method_name string
|
||||||
left Expr
|
left Expr
|
||||||
is_vweb bool
|
is_vweb bool
|
||||||
// vweb_stmts []Stmt
|
|
||||||
vweb_tmpl File
|
vweb_tmpl File
|
||||||
pub mut:
|
pub mut:
|
||||||
sym table.TypeSymbol
|
sym table.TypeSymbol
|
||||||
|
@ -808,6 +807,10 @@ pub:
|
||||||
foo int // todo
|
foo int // todo
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub struct SqlExpr {
|
||||||
|
typ table.Type
|
||||||
|
}
|
||||||
|
|
||||||
[inline]
|
[inline]
|
||||||
pub fn expr_is_blank_ident(expr Expr) bool {
|
pub fn expr_is_blank_ident(expr Expr) bool {
|
||||||
match expr {
|
match expr {
|
||||||
|
|
|
@ -10,7 +10,6 @@ import v.pref
|
||||||
import v.token
|
import v.token
|
||||||
import v.util
|
import v.util
|
||||||
import v.depgraph
|
import v.depgraph
|
||||||
import term
|
|
||||||
|
|
||||||
// NB: keywords after 'new' are reserved in C++
|
// NB: keywords after 'new' are reserved in C++
|
||||||
const (
|
const (
|
||||||
|
@ -1481,6 +1480,9 @@ fn (mut g Gen) expr(node ast.Expr) {
|
||||||
ast.None {
|
ast.None {
|
||||||
g.write('opt_none()')
|
g.write('opt_none()')
|
||||||
}
|
}
|
||||||
|
ast.OrExpr {
|
||||||
|
// this should never appear here
|
||||||
|
}
|
||||||
ast.ParExpr {
|
ast.ParExpr {
|
||||||
g.write('(')
|
g.write('(')
|
||||||
g.expr(it.expr)
|
g.expr(it.expr)
|
||||||
|
@ -1501,6 +1503,9 @@ fn (mut g Gen) expr(node ast.Expr) {
|
||||||
// g.write(')')
|
// g.write(')')
|
||||||
g.is_amp = false
|
g.is_amp = false
|
||||||
}
|
}
|
||||||
|
ast.RangeExpr {
|
||||||
|
// Only used in IndexExpr
|
||||||
|
}
|
||||||
ast.SizeOf {
|
ast.SizeOf {
|
||||||
mut styp := it.type_name
|
mut styp := it.type_name
|
||||||
if it.type_name == '' {
|
if it.type_name == '' {
|
||||||
|
@ -1521,6 +1526,9 @@ fn (mut g Gen) expr(node ast.Expr) {
|
||||||
*/
|
*/
|
||||||
g.write('sizeof($styp)')
|
g.write('sizeof($styp)')
|
||||||
}
|
}
|
||||||
|
ast.SqlExpr {
|
||||||
|
g.write('// sql expression')
|
||||||
|
}
|
||||||
ast.StringLiteral {
|
ast.StringLiteral {
|
||||||
if it.is_raw {
|
if it.is_raw {
|
||||||
escaped_val := it.val.replace_each(['"', '\\"', '\\', '\\\\'])
|
escaped_val := it.val.replace_each(['"', '\\"', '\\', '\\\\'])
|
||||||
|
@ -1583,10 +1591,10 @@ fn (mut g Gen) expr(node ast.Expr) {
|
||||||
g.expr(it.expr)
|
g.expr(it.expr)
|
||||||
g.write(')')
|
g.write(')')
|
||||||
}
|
}
|
||||||
else {
|
//else {
|
||||||
// #printf("node=%d\n", node.typ);
|
// #printf("node=%d\n", node.typ);
|
||||||
println(term.red('cgen.expr(): bad node ' + typeof(node)))
|
//println(term.red('cgen.expr(): bad node ' + typeof(node)))
|
||||||
}
|
//}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -613,6 +613,9 @@ fn (mut g JsGen) expr(node ast.Expr) {
|
||||||
ast.SizeOf {
|
ast.SizeOf {
|
||||||
// TODO
|
// TODO
|
||||||
}
|
}
|
||||||
|
ast.SqlExpr{
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
ast.StringInterLiteral {
|
ast.StringInterLiteral {
|
||||||
g.gen_string_inter_literal(it)
|
g.gen_string_inter_literal(it)
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,9 +19,13 @@ pub fn (mut p Parser) expr(precedence int) ast.Expr {
|
||||||
node = p.parse_assign_ident()
|
node = p.parse_assign_ident()
|
||||||
}
|
}
|
||||||
.name {
|
.name {
|
||||||
|
if p.tok.lit == 'sql' && p.peek_tok.kind == .name {
|
||||||
|
node = p.sql_expr()
|
||||||
|
} else {
|
||||||
node = p.name_expr()
|
node = p.name_expr()
|
||||||
p.is_stmt_ident = is_stmt_ident
|
p.is_stmt_ident = is_stmt_ident
|
||||||
}
|
}
|
||||||
|
}
|
||||||
.string {
|
.string {
|
||||||
node = p.string_expr()
|
node = p.string_expr()
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
|
||||||
|
// Use of this source code is governed by an MIT license
|
||||||
|
// that can be found in the LICENSE file.
|
||||||
|
module parser
|
||||||
|
|
||||||
|
import v.ast
|
||||||
|
|
||||||
|
fn (mut p Parser) sql_expr() ast.SqlExpr {
|
||||||
|
return ast.SqlExpr{}
|
||||||
|
}
|
Loading…
Reference in New Issue