📄 btgetcur.cpp
字号:
/* Copyright (c) 1989 Citadel */
/* All Rights Reserved */
/* #ident "@(#)btgetcur.c 1.4 - 90/06/20" */
#include <blkio.h>
#include <errno.h>
/*#include <string.h>*/
/* local headers */
#include "btree_.h"
/*man---------------------------------------------------------------------------
NAME
btgetcur - get btree cursor
SYNOPSIS
#include <btree.h>
int btgetcur(btp, btposp)
btree_t *btp;
btpos_t *btposp;
DESCRIPTION
The btgetcur function gets the current cursor position for btree
btp and copies it to btposp. A btree position saved with
btgetcur can be used to reposition to a key using btsetcur. It
is important to remember that a btree position is not valid after
an insertion, deletion, or unlock.
btgetcur will fail if one or more of the following is true:
[EINVAL] btp is not a valid btree pointer.
[EINVAL] btposp is the NULL pointer.
[BTELOCK] btp is not locked.
[BTENOPEN] btp is not open.
SEE ALSO
btsetcur.
DIAGNOSTICS
Upon successful completion, a value of 0 is returned. Otherwise,
a value of -1 is returned, and errno set to indicate the error.
------------------------------------------------------------------------------*/
int btgetcur(btree_t *btp, btpos_t *btposp)
{
/* validate arguments */
if (!bt_valid(btp) || btposp == NULL) {
errno = EINVAL;
return -1;
}
/* check if not open */
if (!(btp->flags & BTOPEN)) {
errno = BTENOPEN;
return -1;
}
/* check locks */
if (!(btp->flags & BTLOCKS)) {
errno = BTELOCK;
return -1;
}
/* get current position */
memcpy(btposp, &btp->cbtpos, sizeof(*btposp));
errno = 0;
return 0;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -