Source

htsql-firebird / src / htsql_oracle / core / split_sql.py

#
# Copyright (c) 2006-2011, Prometheus Research, LLC
# See `LICENSE` for license information, `AUTHORS` for the list of authors.
#


"""
:mod:`htsql_engine.oracle.split_sql`
====================================

This module implements the SQL splitter for Oracle.
"""


from htsql.core.split_sql import SQLToken, SplitSQL


class SplitOracle(SplitSQL):
    """
    Implements the SQL splitter for Oracle.
    """

    tokens = [
            # Whitespace between separate statements.
            SQLToken(r"""
                     # whitespaces
                     [\ \t\r\n]+
                     # or a SQL comment
                     | -- [^\r\n]* \r?\n
                     # or a #-comment
                     | \# [^\r\n]* \r?\n
                     # or a C-style comment
                     | /\* .*? \*/
                     """, only_level=0, is_junk=True),

            # The beginning of a SQL statement.
            SQLToken(r""" [a-zA-Z]+ """, only_level=0, delta=+1),

            # The body of function/trigger.
            SQLToken(r""" \b BEGIN \b """, only_level=1, delta=+1),

            # Semicolon in the body of a function.
            SQLToken(r""" ; """, only_level=2),

            # END followed by a semicolon ends a trigger defition.  Note
            # that the semicolon itself must be passed to the server.
            SQLToken(r""" \b END \s* ; """, only_level=2, delta=-2),

            # A block of regular SQL tokens.
            SQLToken(r"""
                     (
                     # whitespaces
                     [\ \t\r\n]+
                     # or a SQL comment
                     | -- [^\r\n]*\r?\n
                     # or a C-style comment
                     | /\* .*? \*/
                     # or a string literal
                     | ' (?: [^'] | '' )* '
                     # or a quoted name
                     | " (?: [^"]+ | "" )+ "
                     # or a keyword or a name (but skip BEGIN/END)
                     | (?!BEGIN\b) (?!END\b) [a-zA-Z_][0-9a-zA-Z_]* \b
                     # or a number
                     | [0-9]+ (?: \. [0-9]* )? (?: [eE] [+-] [0-9]+ )?
                     # or a symbol
                     | [().,:<>=!&|~*/%+-]
                     )+
                     """, min_level=1),

            # Semicolon at the top level indicates the statement end.
            # Note that the server does not accept a semicolon at the
            # end of the statement (unless it is `END;`).
            SQLToken(r""" ; """, only_level=1, delta=-1, is_junk=True),

            # Same for EOF, but it also stops the splitter.
            SQLToken(r""" $ """, only_level=1, delta=-1, is_end=True),

            # EOF outside the statement stops the splitter.
            SQLToken(r""" $ """, only_level=0, is_end=True),
    ]
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.