~ubuntu-branches/ubuntu/precise/kompozer/precise

« back to all changes in this revision

Viewing changes to mozilla/security/nss/cmd/SSLsample/sslerror.h

  • Committer: Bazaar Package Importer
  • Author(s): Anthony Yarusso
  • Date: 2007-08-27 01:11:03 UTC
  • Revision ID: james.westby@ubuntu.com-20070827011103-2jgf4s6532gqu2ka
Tags: upstream-0.7.10
ImportĀ upstreamĀ versionĀ 0.7.10

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * The contents of this file are subject to the Mozilla Public
 
3
 * License Version 1.1 (the "License"); you may not use this file
 
4
 * except in compliance with the License. You may obtain a copy of
 
5
 * the License at http://www.mozilla.org/MPL/
 
6
 * 
 
7
 * Software distributed under the License is distributed on an "AS
 
8
 * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
 
9
 * implied. See the License for the specific language governing
 
10
 * rights and limitations under the License.
 
11
 * 
 
12
 * The Original Code is the Netscape security libraries.
 
13
 * 
 
14
 * The Initial Developer of the Original Code is Netscape
 
15
 * Communications Corporation.  Portions created by Netscape are 
 
16
 * Copyright (C) 1994-2000 Netscape Communications Corporation.  All
 
17
 * Rights Reserved.
 
18
 * 
 
19
 * Contributor(s):
 
20
 * 
 
21
 * Alternatively, the contents of this file may be used under the
 
22
 * terms of the GNU General Public License Version 2 or later (the
 
23
 * "GPL"), in which case the provisions of the GPL are applicable 
 
24
 * instead of those above.  If you wish to allow use of your 
 
25
 * version of this file only under the terms of the GPL and not to
 
26
 * allow others to use your version of this file under the MPL,
 
27
 * indicate your decision by deleting the provisions above and
 
28
 * replace them with the notice and other provisions required by
 
29
 * the GPL.  If you do not delete the provisions above, a recipient
 
30
 * may use your version of this file under either the MPL or the
 
31
 * GPL.
 
32
 */
 
33
 
 
34
#include <stdio.h>
 
35
#include <string.h>
 
36
#include "nspr.h"
 
37
 
 
38
struct tuple_str {
 
39
    PRErrorCode  errNum;
 
40
    const char * errString;
 
41
};
 
42
 
 
43
typedef struct tuple_str tuple_str;
 
44
 
 
45
#define ER2(a,b)   {a, b},
 
46
#define ER3(a,b,c) {a, c},
 
47
 
 
48
#include "secerr.h"
 
49
#include "sslerr.h"
 
50
 
 
51
const tuple_str errStrings[] = {
 
52
 
 
53
/* keep this list in asceding order of error numbers */
 
54
#include "SSLerrs.h"
 
55
#include "SECerrs.h"
 
56
#include "NSPRerrs.h"
 
57
 
 
58
};
 
59
 
 
60
const PRInt32 numStrings = sizeof(errStrings) / sizeof(tuple_str);
 
61
 
 
62
/* Returns a UTF-8 encoded constant error string for "errNum".
 
63
 * Returns NULL of errNum is unknown.
 
64
 */
 
65
const char *
 
66
SSL_Strerror(PRErrorCode errNum) {
 
67
    PRInt32 low  = 0;
 
68
    PRInt32 high = numStrings - 1;
 
69
    PRInt32 i;
 
70
    PRErrorCode num;
 
71
    static int initDone;
 
72
 
 
73
    /* make sure table is in ascending order.
 
74
     * binary search depends on it.
 
75
     */
 
76
    if (!initDone) {
 
77
        PRErrorCode lastNum = (PRInt32)0x80000000;
 
78
        for (i = low; i <= high; ++i) {
 
79
            num = errStrings[i].errNum;
 
80
            if (num <= lastNum) {
 
81
                fprintf(stderr, 
 
82
"sequence error in error strings at item %d\n"
 
83
"error %d (%s)\n"
 
84
"should come after \n"
 
85
"error %d (%s)\n",
 
86
                        i, lastNum, errStrings[i-1].errString, 
 
87
                        num, errStrings[i].errString);
 
88
            }
 
89
            lastNum = num;
 
90
        }
 
91
        initDone = 1;
 
92
    }
 
93
 
 
94
    /* Do binary search of table. */
 
95
    while (low + 1 < high) {
 
96
        i = (low + high) / 2;
 
97
        num = errStrings[i].errNum;
 
98
        if (errNum == num) 
 
99
            return errStrings[i].errString;
 
100
        if (errNum < num)
 
101
            high = i;
 
102
        else 
 
103
            low = i;
 
104
    }
 
105
    if (errNum == errStrings[low].errNum)
 
106
        return errStrings[low].errString;
 
107
    if (errNum == errStrings[high].errNum)
 
108
        return errStrings[high].errString;
 
109
    return NULL;
 
110
}