From: Vladislav Shpilevoy <v.shpilevoy@tarantool.org> To: Kirill Shcherbatov <kshcherbatov@tarantool.org>, tarantool-patches@freelists.org Subject: [tarantool-patches] Re: [PATCH v3 10/10] sql: VDBE tests for trigger existence Date: Mon, 18 Jun 2018 18:42:55 +0300 [thread overview] Message-ID: <04bda6c6-247c-0ad4-b78d-701d1d34c974@tarantool.org> (raw) In-Reply-To: <ad1f65f3-28aa-def0-e539-32c4f35497de@tarantool.org> Thanks for the patch! See 6 comments below. On 15/06/2018 19:21, Kirill Shcherbatov wrote: >> Unfortunately we have the problem with error objects creating. ClientError in >> the constructor increments error counter in statistics visible to user. So this >> still not happened error affects the public API. We need to find another way. >> >> I think, we may assume that this way of error setting will be used for >> ClientErrors only. Indeed, OOM is set explicitly in the place where emerged. Other >> errors are not used in VDBE. The only hindrance is that ClientErrors have >> different argument count. But I have found function box_error_set() in error.h. >> It is a public API to set ClientError with any message. >> >> So lets return to the previous implementation, but instead of passing >> (error code; code arguments) lets pass (error code; the full error message) and >> use box_error_set() instead of direct diag_set(ClientError, ...). >> >> To repeat the same error message format as from the code you can use > > diff --git a/src/box/sql/build.c b/src/box/sql/build.c > index 0edbda1..8db9231 100644 > --- a/src/box/sql/build.c > +++ b/src/box/sql/build.c > @@ -4145,4 +4145,51 @@ sqlite3WithDelete(sqlite3 * db, With * pWith) > sqlite3DbFree(db, pWith); > } > } > + > +int > +parser_emit_execution_halt_on_exists(struct Parse *parser, int space_id, > + int index_id, const char *name_src, > + int tarantool_error_code, > + const char *error_src, bool no_error) 1. Sorry, after discussion with Nikita we have decided to use 'vdbe_' prefix for emitters even if they take parser in first argument. 2. Mismatch of parameter names: error in header, error_src in source. > +{ > + struct Vdbe *v = sqlite3GetVdbe(parser); > + assert(v != NULL); > + > + struct sqlite3 *db = parser->db; > + char *name = NULL; > + char *error = NULL; > + name = sqlite3DbStrDup(db, name_src); > + if (name != NULL) > + error = sqlite3DbStrDup(db, error_src); > + if (name == NULL || error == NULL) { > + size_t size = > + (name != NULL ? strlen(error_src) : > + strlen(name_src)) + 1; > + const char *var_name = name != NULL ? "error" : "name"; > + diag_set(OutOfMemory, size, "sqlite3DbStrDup", var_name); 3. Please, reduce the mess. Separate these OOM handlers. > + sqlite3DbFree(db, name); > + sqlite3DbFree(db, error); > + return -1; > + } > + > + int cursor = parser->nTab++; > + int entity_id = > + SQLITE_PAGENO_FROM_SPACEID_AND_INDEXID(space_id, index_id); > + emit_open_cursor(parser, cursor, entity_id); > + > + int name_reg = parser->nMem++; > + int label = sqlite3VdbeAddOp4(v, OP_String8, 0, name_reg, 0, name, > + P4_DYNAMIC); > + sqlite3VdbeAddOp4Int(v, OP_NoConflict, cursor, label + 3, name_reg, 1); > + if (no_error) { > + sqlite3VdbeAddOp0(v, OP_Halt); > + } else { > + error = sqlite3DbStrDup(db, error); 4. This error is duplicated already above, it is not? > + sqlite3VdbeAddOp4(v, OP_Halt, SQL_TARANTOOL_ERROR, > + ON_CONFLICT_ACTION_FAIL, 0, error, P4_DYNAMIC); > + sqlite3VdbeChangeP5(v, tarantool_error_code); > + } > + sqlite3VdbeAddOp1(v, OP_Close, cursor); > + return 0; > +} > #endif /* !defined(SQLITE_OMIT_CTE) */ > diff --git a/src/box/sql/trigger.c b/src/box/sql/trigger.c > index ec420ea..eadef53 100644 > --- a/src/box/sql/trigger.c > +++ b/src/box/sql/trigger.c > @@ -184,6 +172,20 @@ sqlite3BeginTrigger(Parse * pParse, /* The parse context of the CREATE TRIGGER s > pParse->nErr++; > goto trigger_cleanup; > } > + if (!pParse->parse_only) { > + char error[DIAG_ERRMSG_MAX]; > + snprintf(error, DIAG_ERRMSG_MAX, > + tnt_errcode_desc(ER_TRIGGER_EXISTS), zName); 5. Please, use tt_sprintf. Do not declare big arrays on the stack when possible. > + if (parser_emit_execution_halt_on_exists(pParse, BOX_TRIGGER_ID, > + 0, zName, > + ER_TRIGGER_EXISTS, > + error, > + (noErr != 0)) != 0) { > + pParse->rc = SQL_TARANTOOL_ERROR; > + pParse->nErr++; > + goto trigger_cleanup; > + } > + } > > /* > * INSTEAD OF triggers can only appear on views and BEFORE triggers > diff --git a/src/box/sql/vdbe.c b/src/box/sql/vdbe.c > index c035ffe..5f88e67 100644 > --- a/src/box/sql/vdbe.c > +++ b/src/box/sql/vdbe.c > @@ -1029,7 +1033,10 @@ case OP_Halt: { > p->rc = SQLITE_BUSY; > } else { > assert(rc==SQLITE_OK || (p->rc&0xff)==SQLITE_CONSTRAINT); > - rc = p->rc ? SQLITE_ERROR : SQLITE_DONE; > + if (p->rc != SQL_TARANTOOL_ERROR) > + rc = (p->rc != SQLITE_OK) ? SQLITE_ERROR : SQLITE_DONE; > + else > + rc = SQL_TARANTOOL_ERROR; 6. Earlier this function could return either DONE or ERROR. Now it can return SQL_TARANTOOL_ERROR, and I am not sure that the behavior should be changed in such way. Please, explain why do you need SQL_TARANTOOL_ERROR here. > } > goto vdbe_return; > }
next prev parent reply other threads:[~2018-06-18 15:42 UTC|newest] Thread overview: 38+ messages / expand[flat|nested] mbox.gz Atom feed top 2018-06-14 17:32 [tarantool-patches] [PATCH v3 00/10] sql: remove Triggers to server Kirill Shcherbatov 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 01/10] box: move db->pShchema init to sql_init Kirill Shcherbatov 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 10/10] sql: VDBE tests for trigger existence Kirill Shcherbatov 2018-06-14 19:27 ` [tarantool-patches] " Vladislav Shpilevoy 2018-06-15 16:21 ` Kirill Shcherbatov 2018-06-18 15:42 ` Vladislav Shpilevoy [this message] 2018-06-18 19:22 ` Kirill Shcherbatov 2018-06-19 10:24 ` Vladislav Shpilevoy 2018-06-19 15:12 ` Kirill Shcherbatov 2018-06-19 15:23 ` Vladislav Shpilevoy 2018-06-20 6:38 ` Kirill Shcherbatov 2018-06-20 8:10 ` Vladislav Shpilevoy 2018-06-20 8:24 ` Kirill Shcherbatov 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 02/10] sql: fix leak on CREATE TABLE and resolve self ref Kirill Shcherbatov 2018-06-14 22:46 ` [tarantool-patches] " n.pettik 2018-06-15 9:25 ` Vladislav Shpilevoy 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 03/10] sql: fix sql len in tarantoolSqlite3RenameTrigger Kirill Shcherbatov 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 04/10] box: port schema_find_id to C Kirill Shcherbatov 2018-06-14 19:27 ` [tarantool-patches] " Vladislav Shpilevoy 2018-06-14 22:46 ` n.pettik 2018-06-15 9:25 ` Vladislav Shpilevoy 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 05/10] sql: refactor sql_expr_compile to return AST Kirill Shcherbatov 2018-06-14 19:27 ` [tarantool-patches] " Vladislav Shpilevoy 2018-06-15 16:21 ` Kirill Shcherbatov 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 06/10] sql: move sqlite3DeleteTrigger to sql.h Kirill Shcherbatov 2018-06-14 19:27 ` [tarantool-patches] " Vladislav Shpilevoy 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 07/10] box: sort error codes in misc.test Kirill Shcherbatov 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 08/10] sql: new _trigger space format with space_id Kirill Shcherbatov 2018-06-14 19:27 ` [tarantool-patches] " Vladislav Shpilevoy 2018-06-15 16:21 ` Kirill Shcherbatov 2018-06-14 17:32 ` [tarantool-patches] [PATCH v3 09/10] sql: move Triggers to server Kirill Shcherbatov 2018-06-14 19:27 ` [tarantool-patches] " Vladislav Shpilevoy 2018-06-15 16:21 ` Kirill Shcherbatov 2018-06-18 15:42 ` Vladislav Shpilevoy 2018-06-18 19:22 ` Kirill Shcherbatov 2018-06-14 17:34 ` [tarantool-patches] Re: [PATCH v3 00/10] sql: remove " Kirill Shcherbatov 2018-06-20 8:35 ` Vladislav Shpilevoy 2018-06-28 15:47 ` n.pettik
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=04bda6c6-247c-0ad4-b78d-701d1d34c974@tarantool.org \ --to=v.shpilevoy@tarantool.org \ --cc=kshcherbatov@tarantool.org \ --cc=tarantool-patches@freelists.org \ --subject='[tarantool-patches] Re: [PATCH v3 10/10] sql: VDBE tests for trigger existence' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox