From 5ea9322872c65c5353a305ca5f1c4acfcb486569 Mon Sep 17 00:00:00 2001 From: Peter Eisentraut Date: Sun, 15 Sep 2002 13:04:16 +0000 Subject: [PATCH] Cast functions can be immutable or stable. --- doc/src/sgml/ref/create_cast.sgml | 4 ++-- src/backend/commands/functioncmds.c | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/doc/src/sgml/ref/create_cast.sgml b/doc/src/sgml/ref/create_cast.sgml index 00a4471966..bc9f71e566 100644 --- a/doc/src/sgml/ref/create_cast.sgml +++ b/doc/src/sgml/ref/create_cast.sgml @@ -1,4 +1,4 @@ - + @@ -117,7 +117,7 @@ INSERT INTO foo(f1) VALUES(42); be schema-qualified. If it is not, the function will be looked up in the path. The argument type must be identical to the source type, the result data type must match the target type of - the cast. Cast functions must be marked immutable. + the cast. Cast functions must be marked immutable or stable. diff --git a/src/backend/commands/functioncmds.c b/src/backend/commands/functioncmds.c index 47ebe0d761..a935dae7e6 100644 --- a/src/backend/commands/functioncmds.c +++ b/src/backend/commands/functioncmds.c @@ -9,7 +9,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/commands/functioncmds.c,v 1.19 2002/09/04 20:31:15 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/commands/functioncmds.c,v 1.20 2002/09/15 13:04:16 petere Exp $ * * DESCRIPTION * These routines take the parse tree and pick out the @@ -676,8 +676,8 @@ CreateCast(CreateCastStmt *stmt) elog(ERROR, "argument of cast function must match source data type"); if (procstruct->prorettype != targettypeid) elog(ERROR, "return data type of cast function must match target data type"); - if (procstruct->provolatile != PROVOLATILE_IMMUTABLE) - elog(ERROR, "cast function must be immutable"); + if (procstruct->provolatile == PROVOLATILE_VOLATILE) + elog(ERROR, "cast function must not be volatile"); if (procstruct->proisagg) elog(ERROR, "cast function must not be an aggregate function"); if (procstruct->proretset) -- 2.40.0