diff options
author | vvvv <vvvv@yandex-team.com> | 2024-11-07 12:29:36 +0300 |
---|---|---|
committer | vvvv <vvvv@yandex-team.com> | 2024-11-07 13:49:47 +0300 |
commit | d4c258e9431675bab6745c8638df6e3dfd4dca6b (patch) | |
tree | b5efcfa11351152a4c872fccaea35749141c0b11 /yql/essentials/sql/sql.cpp | |
parent | 13a4f274caef5cfdaf0263b24e4d6bdd5521472b (diff) | |
download | ydb-d4c258e9431675bab6745c8638df6e3dfd4dca6b.tar.gz |
Moved other yql/essentials libs YQL-19206
init
commit_hash:7d4c435602078407bbf20dd3c32f9c90d2bbcbc0
Diffstat (limited to 'yql/essentials/sql/sql.cpp')
-rw-r--r-- | yql/essentials/sql/sql.cpp | 221 |
1 files changed, 221 insertions, 0 deletions
diff --git a/yql/essentials/sql/sql.cpp b/yql/essentials/sql/sql.cpp new file mode 100644 index 0000000000..55409d5ba3 --- /dev/null +++ b/yql/essentials/sql/sql.cpp @@ -0,0 +1,221 @@ +#include "sql.h" + +#include <yql/essentials/core/issue/yql_issue.h> +#include <yql/essentials/sql/v0/sql.h> +#include <yql/essentials/sql/v0/lexer/lexer.h> +#include <yql/essentials/sql/v1/sql.h> +#include <yql/essentials/sql/v1/lexer/lexer.h> +#include <yql/essentials/sql/v1/proto_parser/proto_parser.h> +#include <yql/essentials/parser/pg_wrapper/interface/parser.h> + +#include <google/protobuf/arena.h> + +#include <util/string/builder.h> + +namespace NSQLTranslation { + + NYql::TAstParseResult SqlToYql(const TString& query, const TTranslationSettings& settings, + NYql::TWarningRules* warningRules, NYql::TStmtParseInfo* stmtParseInfo, TTranslationSettings* effectiveSettings) + { + NYql::TAstParseResult result; + TTranslationSettings parsedSettings(settings); + + if (!ParseTranslationSettings(query, parsedSettings, result.Issues)) { + return result; + } + if (effectiveSettings) { + *effectiveSettings = parsedSettings; + } + + google::protobuf::Arena arena; + if (!parsedSettings.Arena) { + parsedSettings.Arena = &arena; + } + + if (!parsedSettings.DeclaredNamedExprs.empty() && !parsedSettings.PgParser && parsedSettings.SyntaxVersion != 1) { + result.Issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "Externally declared named expressions not supported in V0 syntax")); + return result; + } + + if (parsedSettings.PgParser && parsedSettings.PGDisable) { + result.Issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "PG syntax is disabled")); + return result; + } + + if (parsedSettings.PgParser) { + return NSQLTranslationPG::PGToYql(query, parsedSettings, stmtParseInfo); + } + + switch (parsedSettings.SyntaxVersion) { + case 0: + if (settings.V0ForceDisable || parsedSettings.V0Behavior == EV0Behavior::Disable) { + result.Issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "V0 syntax is disabled")); + return result; + } + + if (parsedSettings.AnsiLexer) { + result.Issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "Ansi lexer is not supported in V0 syntax")); + return result; + } + + return NSQLTranslationV0::SqlToYql(query, parsedSettings, warningRules); + case 1: + return NSQLTranslationV1::SqlToYql(query, parsedSettings, warningRules); + default: + result.Issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + TStringBuilder() << "Unknown SQL syntax version: " << parsedSettings.SyntaxVersion)); + return result; + } + } + + google::protobuf::Message* SqlAST(const TString& query, const TString& queryName, NYql::TIssues& issues, + size_t maxErrors, const TTranslationSettings& settings, ui16* actualSyntaxVersion) + { + TTranslationSettings parsedSettings(settings); + if (!ParseTranslationSettings(query, parsedSettings, issues)) { + return nullptr; + } + + if (actualSyntaxVersion) { + *actualSyntaxVersion = parsedSettings.SyntaxVersion; + } + + switch (parsedSettings.SyntaxVersion) { + case 0: + if (settings.V0ForceDisable || settings.V0Behavior == EV0Behavior::Disable) { + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "V0 syntax is disabled")); + return nullptr; + } + + if (parsedSettings.AnsiLexer) { + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "Ansi lexer is not supported in V0 syntax")); + return nullptr; + } + + return NSQLTranslationV0::SqlAST(query, queryName, issues, maxErrors, settings.Arena); + case 1: + return NSQLTranslationV1::SqlAST(query, queryName, issues, maxErrors, parsedSettings.AnsiLexer, parsedSettings.Antlr4Parser, parsedSettings.TestAntlr4, settings.Arena); + default: + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + TStringBuilder() << "Unknown SQL syntax version: " << parsedSettings.SyntaxVersion)); + return nullptr; + } + } + + ILexer::TPtr SqlLexer(const TString& query, NYql::TIssues& issues, const TTranslationSettings& settings, ui16* actualSyntaxVersion) + { + TTranslationSettings parsedSettings(settings); + if (!ParseTranslationSettings(query, parsedSettings, issues)) { + return {}; + } + + if (actualSyntaxVersion) { + *actualSyntaxVersion = parsedSettings.SyntaxVersion; + } + + switch (parsedSettings.SyntaxVersion) { + case 0: + if (settings.V0ForceDisable || settings.V0Behavior == EV0Behavior::Disable) { + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "V0 syntax is disabled")); + return {}; + } + + if (parsedSettings.AnsiLexer) { + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "Ansi lexer is not supported in V0 syntax")); + return {}; + } + + return NSQLTranslationV0::MakeLexer(); + case 1: + return NSQLTranslationV1::MakeLexer(parsedSettings.AnsiLexer, parsedSettings.Antlr4Parser); + default: + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + TStringBuilder() << "Unknown SQL syntax version: " << parsedSettings.SyntaxVersion)); + return {}; + } + } + + NYql::TAstParseResult SqlASTToYql(const google::protobuf::Message& protoAst, const TSQLHints& hints, const TTranslationSettings& settings) { + NYql::TAstParseResult result; + switch (settings.SyntaxVersion) { + case 0: + if (settings.V0ForceDisable || settings.V0Behavior == EV0Behavior::Disable) { + result.Issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "V0 syntax is disabled")); + return result; + } + + if (settings.AnsiLexer) { + result.Issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "Ansi lexer is not supported in V0 syntax")); + return result; + } + + return NSQLTranslationV0::SqlASTToYql(protoAst, settings); + case 1: + return NSQLTranslationV1::SqlASTToYql(protoAst, hints, settings); + default: + result.Issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + TStringBuilder() << "Unknown SQL syntax version: " << settings.SyntaxVersion)); + return result; + } + } + + TVector<NYql::TAstParseResult> SqlToAstStatements(const TString& query, const TTranslationSettings& settings, + NYql::TWarningRules* warningRules, ui16* actualSyntaxVersion, TVector<NYql::TStmtParseInfo>* stmtParseInfo) + { + TVector<NYql::TAstParseResult> result; + NYql::TIssues issues; + TTranslationSettings parsedSettings(settings); + google::protobuf::Arena arena; + if (!parsedSettings.Arena) { + parsedSettings.Arena = &arena; + } + + if (!ParseTranslationSettings(query, parsedSettings, issues)) { + return {}; + } + + if (actualSyntaxVersion) { + *actualSyntaxVersion = parsedSettings.SyntaxVersion; + } + + if (!parsedSettings.DeclaredNamedExprs.empty() && !parsedSettings.PgParser && parsedSettings.SyntaxVersion != 1) { + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "Externally declared named expressions not supported in V0 syntax")); + return {}; + } + + if (parsedSettings.PgParser && parsedSettings.PGDisable) { + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "PG syntax is disabled")); + return result; + } + + if (parsedSettings.PgParser) { + return NSQLTranslationPG::PGToYqlStatements(query, parsedSettings, stmtParseInfo); + } + + switch (parsedSettings.SyntaxVersion) { + case 0: + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + "V0 syntax is disabled")); + return {}; + case 1: + return NSQLTranslationV1::SqlToAstStatements(query, parsedSettings, warningRules, stmtParseInfo); + default: + issues.AddIssue(NYql::YqlIssue(NYql::TPosition(), NYql::TIssuesIds::DEFAULT_ERROR, + TStringBuilder() << "Unknown SQL syntax version: " << parsedSettings.SyntaxVersion)); + return {}; + } + } + +} // namespace NSQLTranslation |