summaryrefslogtreecommitdiffstats
path: root/dom/webidl/ChildSHistory.webidl
blob: e83e01e11faa3f5b019263089ad65f1bb810ad4d (plain)
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
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 * You can obtain one at http://mozilla.org/MPL/2.0/.
 */

interface nsISHistory;

/**
 * The ChildSHistory interface represents the child side of a browsing
 * context's session history.
 */
[ChromeOnly,
 Exposed=Window]
interface ChildSHistory {
  [Pure]
  readonly attribute long count;
  [Pure]
  readonly attribute long index;

  boolean canGo(long aOffset);
  [Throws] void go(long aOffset, optional boolean aRequireUserInteraction = false);

  /**
   * Reload the current entry. The flags which should be passed to this
   * function are documented and defined in nsIWebNavigation.idl
   */
  [Throws]
  void reload(unsigned long aReloadFlags);

  /**
   * Getter for the legacy nsISHistory implementation.
   *
   * legacySHistory has been deprecated. Don't use it, but instead handle
   * the interaction with nsISHistory in the parent process.
   */
  [Throws]
  readonly attribute nsISHistory legacySHistory;

  /**
   * asyncHistoryLength can be enabled to test Fission-like asynchronous
   * history.length handling with non-Fission session history implementation.
   * Throws if session history is running in the parent process.
   */
  [SetterThrows]
  attribute boolean asyncHistoryLength;
};