# HG changeset patch # User Adam Chlipala # Date 1219348801 14400 # Node ID eadeea528f753e451f6951a5bf9a048a645a6d9d # Parent 87d41ac28b30df7c4b57df0c2c3bea68f96fc8ee LIMIT diff -r 87d41ac28b30 -r eadeea528f75 lib/basis.lig --- a/lib/basis.lig Thu Aug 21 15:50:08 2008 -0400 +++ b/lib/basis.lig Thu Aug 21 16:00:01 2008 -0400 @@ -60,10 +60,15 @@ -> sql_exp tables [] t -> sql_order_by tables -> sql_order_by tables +type sql_limit +val sql_no_limit : sql_limit +val sql_limit : int -> sql_limit + val sql_query : tables ::: {{Type}} -> selected ::: {{Type}} -> {Rows : sql_query1 tables selected, - OrderBy : sql_order_by tables} + OrderBy : sql_order_by tables, + Limit : sql_limit} -> sql_query selected val sql_field : otherTabs ::: {{Type}} -> otherFields ::: {Type} -> fieldType ::: Type -> agg ::: {{Type}} diff -r 87d41ac28b30 -r eadeea528f75 src/lacweb.grm --- a/src/lacweb.grm Thu Aug 21 15:50:08 2008 -0400 +++ b/src/lacweb.grm Thu Aug 21 16:00:01 2008 -0400 @@ -164,6 +164,7 @@ | SELECT | FROM | AS | CWHERE | GROUP | ORDER | BY | HAVING | UNION | INTERSECT | EXCEPT + | LIMIT | OFFSET | TRUE | FALSE | CAND | OR | NOT | NE | LT | LE | GT | GE @@ -245,6 +246,8 @@ | hopt of exp | obopt of exp | obexps of exp + | lopt of exp + | sqlint of exp %verbose (* print summary of errors *) @@ -658,13 +661,15 @@ | STRING (EPrim (Prim.String STRING), s (STRINGleft, STRINGright)) | LBRACE eexp RBRACE (eexp) -query : query1 obopt (let +query : query1 obopt lopt (let val loc = s (query1left, query1right) val re = (ERecord [((CName "Rows", loc), query1), ((CName "OrderBy", loc), - obopt)], loc) + obopt), + ((CName "Limit", loc), + lopt)], loc) in (EApp ((EVar (["Basis"], "sql_query"), loc), re), loc) end) @@ -844,3 +849,13 @@ in (EApp (e, obexps), loc) end) + +lopt : (EVar (["Basis"], "sql_no_limit"), dummy) + | LIMIT sqlint (let + val loc = s (LIMITleft, sqlintright) + in + (EApp ((EVar (["Basis"], "sql_limit"), loc), sqlint), loc) + end) + +sqlint : INT (EPrim (Prim.Int INT), s (INTleft, INTright)) + | LBRACE eexp RBRACE (eexp) diff -r 87d41ac28b30 -r eadeea528f75 src/lacweb.lex --- a/src/lacweb.lex Thu Aug 21 15:50:08 2008 -0400 +++ b/src/lacweb.lex Thu Aug 21 16:00:01 2008 -0400 @@ -309,6 +309,8 @@ "ORDER" => (Tokens.ORDER (pos yypos, pos yypos + size yytext)); "BY" => (Tokens.BY (pos yypos, pos yypos + size yytext)); "HAVING" => (Tokens.HAVING (pos yypos, pos yypos + size yytext)); + "LIMIT" => (Tokens.LIMIT (pos yypos, pos yypos + size yytext)); + "OFFSET" => (Tokens.OFFSET (pos yypos, pos yypos + size yytext)); "UNION" => (Tokens.UNION (pos yypos, pos yypos + size yytext)); "INTERSECT" => (Tokens.INTERSECT (pos yypos, pos yypos + size yytext)); diff -r 87d41ac28b30 -r eadeea528f75 tests/limit.lac --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tests/limit.lac Thu Aug 21 16:00:01 2008 -0400 @@ -0,0 +1,4 @@ +table t : {A : int, B : string, C : float} + +val q1 = (SELECT * FROM t LIMIT 42) +val q2 = fn n => (SELECT * FROM t LIMIT {n})