package SQL::Translator::Parser::SQLite;
# -------------------------------------------------------------------
-# $Id: SQLite.pm,v 1.8 2006-06-07 16:08:45 schiffbruechige Exp $
+# $Id$
# -------------------------------------------------------------------
# Copyright (C) 2002-4 SQLFairy Authors
#
use strict;
use vars qw[ $DEBUG $VERSION $GRAMMAR @EXPORT_OK ];
-$VERSION = sprintf "%d.%02d", q$Revision: 1.8 $ =~ /(\d+)\.(\d+)/;
+$VERSION = sprintf "%d.%02d", q$Revision$ =~ /(\d+)\.(\d+)/;
$DEBUG = 0 unless defined $DEBUG;
use Data::Dumper;
#
# Create Trigger
-create : CREATE TEMPORARY(?) TRIGGER NAME before_or_after(?) database_event ON table_name trigger_action
+create : CREATE TEMPORARY(?) TRIGGER NAME before_or_after(?) database_event ON table_name trigger_action SEMICOLON
{
my $table_name = $item[8]->{'name'};
push @triggers, {
instead_of => 0,
db_event => $item[6],
action => $item[9],
+ on_table => $table_name,
}
}
instead_of => 1,
db_event => $item[6],
action => $item[9],
+ on_table => $table_name,
}
}
when : WHEN expr { $item[2] }
-trigger_step : /(select|delete|insert|update)/i /[^;]+/ SEMICOLON
+string :
+ /'(\\.|''|[^\\\'])*'/
+
+nonstring : /[^;\'"]+/
+
+statement_body : (string | nonstring)(s?)
+
+trigger_step : /(select|delete|insert|update)/i statement_body SEMICOLON
{
- $return = join( ' ', $item[1], $item[2] )
+ $return = join( ' ', $item[1], join ' ', @{ $item[2] || [] } )
}
before_or_after : /(before|after)/i { $return = lc $1 }
perform_action_when => $def->{'when'},
database_event => $def->{'db_event'},
action => $def->{'action'},
+ on_table => $def->{'on_table'},
);
}