1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
|
/*****************************************************************************
Copyright (c) 1998, 2025, Oracle and/or its affiliates.
This program is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License, version 2.0, as published by the
Free Software Foundation.
This program is designed to work with certain software (including
but not limited to OpenSSL) that is licensed under separate terms,
as designated in a particular file or component or in included license
documentation. The authors of MySQL hereby grant you an additional
permission to link the program and your derivative works with the
separately licensed software that they have either included with
the program or referenced in the documentation.
This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the GNU General Public License, version 2.0,
for more details.
You should have received a copy of the GNU General Public License along with
this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*****************************************************************************/
/** @file include/eval0proc.h
Executes SQL stored procedures and their control structures
Created 1/20/1998 Heikki Tuuri
*******************************************************/
#ifndef eval0proc_h
#define eval0proc_h
#include "pars0pars.h"
#include "pars0sym.h"
#include "que0types.h"
#include "univ.i"
/** Performs an execution step of a procedure node.
@return query thread to run next or NULL */
static inline que_thr_t *proc_step(que_thr_t *thr); /*!< in: query thread */
/** Performs an execution step of an if-statement node.
@return query thread to run next or NULL */
que_thr_t *if_step(que_thr_t *thr); /*!< in: query thread */
/** Performs an execution step of a while-statement node.
@return query thread to run next or NULL */
que_thr_t *while_step(que_thr_t *thr); /*!< in: query thread */
/** Performs an execution step of a for-loop node.
@return query thread to run next or NULL */
que_thr_t *for_step(que_thr_t *thr); /*!< in: query thread */
/** Performs an execution step of an assignment statement node.
@return query thread to run next or NULL */
que_thr_t *assign_step(que_thr_t *thr); /*!< in: query thread */
/** Performs an execution step of a procedure call node.
@return query thread to run next or NULL */
static inline que_thr_t *proc_eval_step(
que_thr_t *thr); /*!< in: query thread */
/** Performs an execution step of an exit statement node.
@return query thread to run next or NULL */
que_thr_t *exit_step(que_thr_t *thr); /*!< in: query thread */
/** Performs an execution step of a return-statement node.
@return query thread to run next or NULL */
que_thr_t *return_step(que_thr_t *thr); /*!< in: query thread */
#include "eval0proc.ic"
#endif
|