/* * Copyright (c) 2001, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code 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 General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. * */ package sun.jvm.hotspot.ui; import javax.swing.JComponent; /** An EditorFactory is the basis of pluggable editor components. One can configure the debugger with a new EditorFactory, which completely replaces how the debugger displays source code. */ public interface EditorFactory { /** Opens the given file in a new window. The debugger has already taken care of ensuring that the file can be found. The debugger will typically not create two Editor objects for the same source file, as it keeps track of open files. The EditorCommands object provided to the Editor by the debugger allows the Editor to notify the debugger of events such as a breakpoint being set or a window being closed. */ public Editor openFile(String filename, EditorCommands commands); /** Retrieves the current topmost file of all of the Editors this EditorFactory has opened. This is used for the debugger user interface to request that a breakpoint be set. (Editors can also request that breakpoints be set via the EditorCommands, but this is intended to support external editors with their own keystrokes for performing this operation.) Returns null if there is no file currently being edited. */ public Editor getCurrentEditor(); }