File: newerror

package info (click to toggle)
calc 2.15.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 7,848 kB
  • sloc: ansic: 62,147; makefile: 7,664; sh: 503; awk: 74; sed: 7
file content (98 lines) | stat: -rw-r--r-- 3,253 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
NAME
    newerror - create or recall a user defined error condition

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.

    When this function is called, the  global calc error count (see
    help errcount) is incremented.  If the global calc error count
    exceeds the maximum count (see help errmax), any ongoing calc
    execution is aborted.

    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 E_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 E__USERMAX-E__USERDEF
    (which is usually 12767 calls to the newerror function).

LINK LIBRARY
    none

SEE ALSO
    errcount, errmax, errno, errorcodes, errsym, iserror, stoponerror, strerror

## Copyright (C) 1999-2006,2023  Landon Curt Noll
##
## Calc is open software; you can redistribute it and/or modify it under
## the terms of the version 2.1 of the GNU Lesser General Public License
## as published by the Free Software Foundation.
##
## Calc is distributed in the hope that it will be useful, but WITHOUT
## ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
## or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General
## Public License for more details.
##
## A copy of version 2.1 of the GNU Lesser General Public License is
## distributed with calc under the filename COPYING-LGPL.  You should have
## received a copy with calc; if not, write to Free Software Foundation, Inc.
## 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
##
## Under source code control:   1996/04/30 03:39:56
## File existed as early as:    1996
##
## chongo <was here> /\oo/\     http://www.isthe.com/chongo/
## Share and enjoy!  :-)        http://www.isthe.com/chongo/tech/comp/calc/