1999-10-15 11:23:53 +04:00
|
|
|
/* -*- Mode: IDL; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla 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/MPL/
|
|
|
|
*
|
|
|
|
* 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 the Mozilla browser.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape
|
|
|
|
* Communications, Inc. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1999, Mozilla. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Travis Bogard <travis@netscape.com>
|
1999-10-21 07:01:33 +04:00
|
|
|
* Steve Clark <buster@netscape.com>
|
1999-10-15 11:23:53 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "nsISupports.idl"
|
|
|
|
#include "domstubs.idl"
|
1999-10-21 07:01:33 +04:00
|
|
|
#include "nsIPref.idl"
|
1999-11-06 07:48:21 +03:00
|
|
|
#include "nsIURIContentListener.idl"
|
1999-11-07 12:57:56 +03:00
|
|
|
#include "nsIURI.idl"
|
1999-10-15 11:23:53 +04:00
|
|
|
|
1999-10-22 06:26:35 +04:00
|
|
|
%{ C++
|
|
|
|
#include "nsIPresContext.h"
|
1999-11-11 03:35:36 +03:00
|
|
|
#include "nsIDocumentLoaderObserver.h"
|
1999-10-22 06:26:35 +04:00
|
|
|
%}
|
|
|
|
|
1999-10-15 11:23:53 +04:00
|
|
|
/**
|
|
|
|
* The nsIDocShell
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
{69E5DE00-7B8B-11d3-AF61-00A024FFC08C} -
|
|
|
|
{69E5DE99-7B8B-11d3-AF61-00A024FFC08C} have been reserved for DocShell
|
|
|
|
Interfaces.
|
|
|
|
|
|
|
|
Currently Used:
|
|
|
|
{69E5DE00-7B8B-11d3-AF61-00A024FFC08C} - nsIDocShell
|
|
|
|
{69E5DE01-7B8B-11d3-AF61-00A024FFC08C} - nsIDocShellFile
|
|
|
|
{69E5DE02-7B8B-11d3-AF61-00A024FFC08C} - nsIDocShellEdit
|
|
|
|
{69E5DE03-7B8B-11d3-AF61-00A024FFC08C} - nsIHTMLDocShell
|
1999-10-21 07:01:33 +04:00
|
|
|
{69E5DE04-7B8B-11d3-AF61-00A024FFC08C} - nsIDocShellContainer
|
1999-10-15 11:23:53 +04:00
|
|
|
*/
|
|
|
|
|
1999-10-21 07:01:33 +04:00
|
|
|
[ptr] native nsIPresContext(nsIPresContext);
|
1999-11-11 03:35:36 +03:00
|
|
|
[ptr] native nsIDocumentLoaderObserver(nsIDocumentLoaderObserver);
|
1999-10-21 07:01:33 +04:00
|
|
|
|
1999-10-15 11:23:53 +04:00
|
|
|
[scriptable, uuid(69E5DE00-7B8B-11d3-AF61-00A024FFC08C)]
|
|
|
|
interface nsIDocShell : nsISupports
|
|
|
|
{
|
1999-10-21 07:01:33 +04:00
|
|
|
/*
|
|
|
|
Loads a given URI. This will give priority to loading the requested URI
|
|
|
|
in the object implementing this interface. If it can't be loaded here
|
|
|
|
however, the URL dispatcher will go through its normal process of content
|
|
|
|
loading.
|
|
|
|
|
|
|
|
@param uri - The URI to load.
|
1999-10-30 06:30:13 +04:00
|
|
|
@param presContext - Presentation Context to use for the new URL. This
|
|
|
|
may be null.
|
1999-10-21 07:01:33 +04:00
|
|
|
*/
|
1999-11-07 12:57:56 +03:00
|
|
|
[noscript]void loadURI(in nsIURI uri, in nsIPresContext presContext);
|
1999-10-21 07:01:33 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
Loads a given URI through the specified adapter. This will give priority
|
|
|
|
to loading the requested URI in the object implementing this interface.
|
|
|
|
If it can't be loaded here however, the URL dispatcher will go through its
|
|
|
|
normal process of content loading.
|
|
|
|
|
|
|
|
@param uri - The URI to load.
|
1999-10-30 06:30:13 +04:00
|
|
|
@param presContext - Presentation Context to use for the new URL. This
|
|
|
|
may be null.
|
1999-10-21 07:01:33 +04:00
|
|
|
@param adapterBinding - The local IP address of the adapter to bind to.
|
|
|
|
*/
|
1999-11-07 12:57:56 +03:00
|
|
|
[noscript]void loadURIVia(in nsIURI uri, in nsIPresContext presContext,
|
1999-10-30 06:30:13 +04:00
|
|
|
in unsigned long adapterBinding);
|
1999-10-15 11:23:53 +04:00
|
|
|
|
1999-10-21 07:01:33 +04:00
|
|
|
/*
|
1999-10-30 06:30:13 +04:00
|
|
|
Sets the current document to the one being passed in. This will simulate
|
|
|
|
a load.
|
|
|
|
|
|
|
|
@param document - The document to load.
|
1999-11-11 03:35:36 +03:00
|
|
|
@param rootNode - The root of the document content, to be hooked up
|
1999-10-30 06:30:13 +04:00
|
|
|
*/
|
1999-11-11 03:35:36 +03:00
|
|
|
[noscript]void setDocument(in nsIDOMDocument document, in nsIDOMElement rootNode);
|
1999-10-30 06:30:13 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
The current document that is loaded in the DocShell.
|
1999-10-21 07:01:33 +04:00
|
|
|
*/
|
1999-10-30 06:30:13 +04:00
|
|
|
readonly attribute nsIDOMDocument document;
|
1999-10-21 07:01:33 +04:00
|
|
|
|
1999-11-07 12:57:56 +03:00
|
|
|
/*
|
|
|
|
The current URI that is loaded.
|
|
|
|
*/
|
|
|
|
readonly attribute nsIURI currentURI;
|
|
|
|
|
1999-11-11 03:35:36 +03:00
|
|
|
/* clients may get and set an nsIDocumentLoaderObserver, which will be notified
|
|
|
|
* during loadURI, loadURIVia, and setDocument
|
|
|
|
*/
|
|
|
|
attribute nsIDocumentLoaderObserver docLoaderObserver;
|
|
|
|
|
1999-10-21 07:01:33 +04:00
|
|
|
/*
|
|
|
|
name of the DocShell
|
|
|
|
*/
|
|
|
|
attribute wstring name;
|
|
|
|
|
|
|
|
/*
|
1999-10-30 06:30:13 +04:00
|
|
|
Presentation context for the currently loaded document. This may be null.
|
1999-10-21 07:01:33 +04:00
|
|
|
*/
|
1999-10-30 06:30:13 +04:00
|
|
|
readonly attribute nsIPresContext presContext;
|
1999-10-21 07:01:33 +04:00
|
|
|
|
|
|
|
/*
|
1999-11-06 07:48:21 +03:00
|
|
|
Parent DocShell.. Note Implementers of this interface should NOT effect
|
|
|
|
the lifetime of the parent DocShell by holding this reference as it creates
|
|
|
|
a cycle. Parents when releasing this interface should set the parent to
|
|
|
|
nsnull. Implementers of this interface are guaranteed that when parent is
|
|
|
|
set that the pointer is valid without having to addref.
|
|
|
|
|
|
|
|
Further note however when others try to Get the interface you should add
|
|
|
|
ref it before handing it to them.
|
1999-10-21 07:01:33 +04:00
|
|
|
*/
|
|
|
|
attribute nsIDocShell parent;
|
|
|
|
|
1999-11-06 07:48:21 +03:00
|
|
|
/*
|
|
|
|
URI content listener parent
|
|
|
|
*/
|
|
|
|
attribute nsIURIContentListener parentURIContentListener;
|
|
|
|
|
1999-10-26 13:51:36 +04:00
|
|
|
/*
|
|
|
|
Returns true if the given docshell can handle the requested content type.
|
|
|
|
*/
|
|
|
|
boolean canHandleContentType(in wstring contentType);
|
|
|
|
|
1999-10-21 07:01:33 +04:00
|
|
|
/*
|
|
|
|
Prefs to use for the DocShell.
|
|
|
|
*/
|
1999-10-25 08:51:15 +04:00
|
|
|
attribute nsIPref prefs;
|
1999-10-21 07:01:33 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
Returns the root DocShell instance. Since DocShells can be nested
|
|
|
|
(when frames are present for example) this instance represents the
|
|
|
|
outermost DocShell.
|
|
|
|
*/
|
|
|
|
readonly attribute nsIDocShell rootDocShell;
|
1999-10-30 04:52:57 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set/Get the document scale factor. When setting this attribute, a
|
|
|
|
* NS_ERROR_NOT_IMPLEMENTED error may be returned by implementations
|
|
|
|
* not supporting zoom. Implementations not supporting zoom should return
|
|
|
|
* 1.0 all the time for the Get operation. 1.0 by the way is the default
|
|
|
|
* of zoom. This means 100% of normal scaling or in other words normal size
|
|
|
|
* no zoom.
|
|
|
|
*/
|
|
|
|
attribute float zoom;
|
1999-10-15 11:23:53 +04:00
|
|
|
};
|