postgresql/src/backend/utils/adt/oid.c

238 lines
4.2 KiB
C
Raw Normal View History

/*-------------------------------------------------------------------------
*
* oid.c
* Functions for the built-in type Oid.
*
* Copyright (c) 1994, Regents of the University of California
*
*
* IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/adt/oid.c,v 1.31 2000/01/10 15:41:26 momjian Exp $
*
*-------------------------------------------------------------------------
*/
#include <ctype.h>
#include "postgres.h"
1999-07-16 05:14:30 +02:00
#include "utils/builtins.h"
/*****************************************************************************
* USER I/O ROUTINES *
*****************************************************************************/
/*
* oid8in - converts "num num ..." to internal form
*
* Note:
* Fills any nonexistent digits with NULL oids.
*/
Oid *
oid8in(char *oidString)
{
1998-09-22 22:28:15 +02:00
Oid *result;
int slot;
if (oidString == NULL)
1998-09-01 05:29:17 +02:00
return NULL;
1998-09-22 22:28:15 +02:00
result = (Oid *) palloc(sizeof(Oid[INDEX_MAX_KEYS]));
for (slot=0; *oidString && slot < INDEX_MAX_KEYS; slot++)
{
if (sscanf(oidString, "%u", &result[slot]) != 1)
break;
while (*oidString && isspace(*oidString))
oidString++;
while (*oidString && !isspace(*oidString))
oidString++;
}
while (*oidString && isspace(*oidString))
oidString++;
if (*oidString)
elog(ERROR,"oid8 value has too many values");
while (slot < INDEX_MAX_KEYS)
result[slot++] = 0;
1998-09-22 22:28:15 +02:00
return result;
}
/*
* oid8out - converts internal form to "num num ..."
*/
char *
1998-09-22 22:28:15 +02:00
oid8out(Oid *oidArray)
{
int num, maxnum;
char *rp;
char *result;
if (oidArray == NULL)
{
result = (char *) palloc(2);
result[0] = '-';
result[1] = '\0';
1998-09-01 05:29:17 +02:00
return result;
}
/* find last non-zero value in vector */
for (maxnum = INDEX_MAX_KEYS-1; maxnum >= 0; maxnum--)
if (oidArray[maxnum] != 0)
break;
/* assumes sign, 10 digits, ' ' */
rp = result = (char *) palloc(maxnum * 12 + 1);
for (num = 0; num <= maxnum; num++)
{
if (num != 0)
*rp++ = ' ';
ltoa(oidArray[num], rp);
while (*++rp != '\0')
;
}
*rp = '\0';
1998-09-01 05:29:17 +02:00
return result;
}
Oid
oidin(char *s)
{
1998-09-01 05:29:17 +02:00
return int4in(s);
}
char *
oidout(Oid o)
{
1998-09-01 05:29:17 +02:00
return int4out(o);
}
/*****************************************************************************
* PUBLIC ROUTINES *
*****************************************************************************/
/*
* If you change this function, change heap_keytest()
* because we have hardcoded this in there as an optimization
*/
bool
oideq(Oid arg1, Oid arg2)
{
1998-09-01 05:29:17 +02:00
return arg1 == arg2;
}
bool
oidne(Oid arg1, Oid arg2)
{
1998-09-01 05:29:17 +02:00
return arg1 != arg2;
}
bool
1998-09-01 05:29:17 +02:00
oid8eq(Oid *arg1, Oid *arg2)
{
return (bool) (memcmp(arg1, arg2, INDEX_MAX_KEYS * sizeof(Oid)) == 0);
}
1998-10-29 19:07:09 +01:00
bool
oid8ne(Oid *arg1, Oid *arg2)
{
return (bool) (memcmp(arg1, arg2, INDEX_MAX_KEYS * sizeof(Oid)) != 0);
1998-10-29 19:07:09 +01:00
}
bool
1998-09-01 05:29:17 +02:00
oid8lt(Oid *arg1, Oid *arg2)
{
int i;
for (i = 0; i < INDEX_MAX_KEYS; i++)
if (!int4eq(arg1[i], arg2[i]))
return int4lt(arg1[i], arg2[i]);
return false;
}
bool
1998-09-01 05:29:17 +02:00
oid8le(Oid *arg1, Oid *arg2)
{
int i;
for (i = 0; i < INDEX_MAX_KEYS; i++)
if (!int4eq(arg1[i], arg2[i]))
return int4le(arg1[i], arg2[i]);
return true;
}
bool
1998-09-01 05:29:17 +02:00
oid8ge(Oid *arg1, Oid *arg2)
{
int i;
for (i = 0; i < INDEX_MAX_KEYS; i++)
if (!int4eq(arg1[i], arg2[i]))
return int4ge(arg1[i], arg2[i]);
return true;
}
bool
1998-09-01 05:29:17 +02:00
oid8gt(Oid *arg1, Oid *arg2)
{
int i;
for (i = 0; i < INDEX_MAX_KEYS; i++)
if (!int4eq(arg1[i], arg2[i]))
return int4gt(arg1[i], arg2[i]);
return false;
}
bool
oideqint4(Oid arg1, int32 arg2)
{
/* oid is unsigned, but int4 is signed */
1998-09-01 05:29:17 +02:00
return arg2 >= 0 && arg1 == arg2;
}
bool
int4eqoid(int32 arg1, Oid arg2)
{
/* oid is unsigned, but int4 is signed */
1998-09-01 05:29:17 +02:00
return arg1 >= 0 && arg1 == arg2;
}
text *
oid_text(Oid oid)
{
text *result;
int len;
char *str;
str = oidout(oid);
len = (strlen(str) + VARHDRSZ);
result = palloc(len);
VARSIZE(result) = len;
memmove(VARDATA(result), str, (len - VARHDRSZ));
pfree(str);
1998-09-01 05:29:17 +02:00
return result;
} /* oid_text() */
Oid
text_oid(text *string)
{
Oid result;
int len;
char *str;
len = (VARSIZE(string) - VARHDRSZ);
str = palloc(len + 1);
memmove(str, VARDATA(string), len);
*(str + len) = '\0';
result = oidin(str);
pfree(str);
1998-09-01 05:29:17 +02:00
return result;
} /* oid_text() */