File: JSErrorReporter.java

package info (click to toggle)
spidermonkey 1.5rc6a-1
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 6,676 kB
  • ctags: 11,462
  • sloc: ansic: 82,178; cpp: 11,392; java: 859; perl: 722; makefile: 638; asm: 75; awk: 20; sh: 7
file content (74 lines) | stat: -rw-r--r-- 2,718 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
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 *
 * The contents of this file are subject to the Netscape Public
 * License Version 1.1 (the "License"); you may not use this file
 * except in compliance with the License. You may obtain a copy of
 * the License at http://www.mozilla.org/NPL/
 *
 * Software distributed under the License is distributed on an "AS
 * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
 * implied. See the License for the specific language governing
 * rights and limitations under the License.
 *
 * The Original Code is mozilla.org code.
 *
 * The Initial Developer of the Original Code is Netscape
 * Communications Corporation.  Portions created by Netscape are
 * Copyright (C) 1998 Netscape Communications Corporation. All
 * Rights Reserved.
 *
 * Contributor(s): 
 */

package netscape.jsdebug;

/**
* This is a special kind of hook to respond to JavaScript errors
*
* @author  John Bandhauer
* @version 1.0
* @since   1.0
*/
public interface JSErrorReporter
{
    /* keep these in sync with the numbers in jsdebug.h */

    /**
    * returned by <code>reportError()</code> to indicate that the error
    * should be passed along to the error reporter that would have been 
    * called had the debugger not been running
    */
    public static final int PASS_ALONG = 0;
    /**
    * returned by <code>reportError()</code> to indicate that the 
    * normal error reporter should not be called and that the JavaScript
    * engine should do whatever it would normally do after calling the
    * error reporter.
    */
    public static final int RETURN     = 1;
    /**
    * returned by <code>reportError()</code> to indicate that the 
    * 'debug break' hook should be called to allow the debugger to 
    * investigate the state of the process when the error occured
    */
    public static final int DEBUG      = 2;

    /**
    * This hook is called when a JavaScript error (compile or runtime) occurs
    * <p> 
    * One of the codes above should be returned to tell the engine how to 
    * proceed.
    * @param msg error message passed through from the JavaScript engine
    * @param filename filename (or url) of the code with the error
    * @param lineno line number where error was detected
    * @param linebuf a copy of the line where the error was detected
    * @param tokenOffset the offset into <i>linebuf</i> where the error 
    * was detected
    * @returns one of the codes above
    */
    public int reportError( String msg,
                            String filename,
                            int    lineno,
                            String linebuf,
                            int    tokenOffset );
}