NAME
    newerror - create or recall a described error-value

SYNOPSIS
    newerror([str])

TYPES
    str		string

    return	error-value

DESCRIPTION
    If str is not "" and has not earlier been used as an argument for
    this function, newerror(str) creates a new described error-value so
    that any future use of newerror(str) with the same str will return
    the same error-value.

    If x = newerror(str), both strerror(x) and strerror(iserro(x)) will
    return str and iserror(x) will return the error code value of the
    new error.

    The null cases newerror() and newerror("") are equivalent to
    newerror("???").

EXAMPLE
    Note that by default, errmax() is 0 so unless errmax() is
    increased you will get:

    > ba = newerror("curds n' whey");
    Error 20000 caused errcount to exceed errmax

    > errmax(errcount()+5)
	    0
    > e1 = newerror("triangle side length <= 0")
    > iserror(e1)
	    20000
    > error(20000)
	    Error 20000
    > strerror(error(20000))
	    "triangle side length <= 0"
    > strerror(e1);
	    "triangle side length <= 0"
    > strerror(error(iserror(e1)))
	    "triangle side length <= 0"

    > define area(a,b,c) {
    >>	local s;
    >>	if (!(a > 0) || !(b > 0) || !(c > 0)) return e1;
    >>	s = (a + b + c)/2;
    >>	if (s <= a || s <= b || s <= c) return newerror("Non-triangle sides");
    >>	return sqrt(s * (s - a) * (s - b) * (s - c));
    >> }
    "area" defined

    > A = area(8,2,5);
    > if (iserror(A)) print strerror(A) : ":", iserror(A);
    Non-triangle sides: 20001

    > A = area(-3,4,5)
    > if (iserror(A)) print strerror(A) : ":", iserror(A);
    triangle side length <= 0: 20000

LIMITS
    The number of new described error-values is not to exceed 12767.

LIBRARY
    none

SEE ALSO
    errmax, errcount, error, strerror, iserror, errno, errorcodes
