/* -------------------------------------------------------------------------
 *  This file is part of the oGRAC project.
 * Copyright (c) 2024 Huawei Technologies Co.,Ltd.
 *
 * oGRAC is licensed under Mulan PSL v2.
 * You can use this software according to the terms and conditions of the Mulan PSL v2.
 * You may obtain a copy of Mulan PSL v2 at:
 *
 *          http://license.coscl.org.cn/MulanPSL2
 *
 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
 * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
 * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
 * See the Mulan PSL v2 for more details.
 * -------------------------------------------------------------------------
 *
 * ogsql_hash_mtrl.h
 *
 *
 * IDENTIFICATION
 * src/ogsql/executor/ogsql_hash_mtrl.h
 *
 * -------------------------------------------------------------------------
 */
#ifndef __SQL_HASH_MTRL_H__
#define __SQL_HASH_MTRL_H__

#include "ogsql_group.h"

#define HASH_MTRL_CONTEXT(cursor) ((cursor)->hash_mtrl_ctx)
#define HASH_MTRL_GROUP_CONTEXT (&HASH_MTRL_CONTEXT(cursor)->group_ctx)
#define HASH_MTRL_SEGMENT (&HASH_MTRL_GROUP_CONTEXT->hash_segment)
#define HASH_MTRL_TABLE_ENTRY (&HASH_MTRL_GROUP_CONTEXT->group_hash_table)
#define HASH_MTRL_TABLE_ITER (&HASH_MTRL_GROUP_CONTEXT->iters[0])

status_t sql_execute_hash_mtrl(sql_stmt_t *stmt, sql_cursor_t *cursor, plan_node_t *plan);
status_t sql_fetch_hash_mtrl(sql_stmt_t *stmt, sql_cursor_t *cursor, plan_node_t *plan, bool32 *eof);

#endif