Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1057)

Unified Diff: Source/core/frame/Window.idl

Issue 984943002: Sync the Window interface with the many specs (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: update test Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « Source/core/frame/UseCounter.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Source/core/frame/Window.idl
diff --git a/Source/core/frame/Window.idl b/Source/core/frame/Window.idl
index 294d143f8a949c2295e6c42008ea31259cf0b219..006a11d949f4e4de69420216929c0824e4dc64cf 100644
--- a/Source/core/frame/Window.idl
+++ b/Source/core/frame/Window.idl
@@ -34,11 +34,13 @@
PrimaryGlobal,
] interface Window : EventTarget {
// the current browsing context
- [DoNotCheckSecurity, Unforgeable] readonly attribute Window window;
+ // FIXME: The spec uses the WindowProxy type for this and many other attributes.
+ [Unforgeable, DoNotCheckSecurity] readonly attribute Window window;
[Replaceable, DoNotCheckSecurity] readonly attribute Window self;
+ // FIXME: document should be [Unforgeable].
readonly attribute Document document;
attribute DOMString name;
- [DoNotCheckSecurity, PutForwards=href, Unforgeable] readonly attribute Location location;
+ [PutForwards=href, Unforgeable, DoNotCheckSecurity] readonly attribute Location location;
readonly attribute History history;
[Replaceable, MeasureAs=BarPropLocationbar] readonly attribute BarProp locationbar;
[Replaceable, MeasureAs=BarPropMenubar] readonly attribute BarProp menubar;
@@ -56,15 +58,16 @@
// other browsing contexts
[Replaceable, DoNotCheckSecurity] readonly attribute Window frames;
[Replaceable, DoNotCheckSecurity] readonly attribute unsigned long length;
- [DoNotCheckSecurity, Unforgeable] readonly attribute Window top;
+ [Unforgeable, DoNotCheckSecurity] readonly attribute Window top;
+ // FIXME: opener should be of type any.
[DoNotCheckSecurity, Custom=Setter] attribute Window opener;
[Replaceable, DoNotCheckSecurity] readonly attribute Window parent;
- [CheckSecurity=Node, Custom=Getter] readonly attribute Element frameElement;
- [Custom] Window open(DOMString url,
- DOMString name,
- optional DOMString options);
+ [CheckSecurity=Node, Custom=Getter] readonly attribute Element? frameElement;
+ // FIXME: open() should have 4 optional arguments with defaults.
+ [Custom] Window open(DOMString url, DOMString target, optional DOMString features);
+ // FIXME: These getters should not have [NotEnumerable].
[NotEnumerable, DoNotCheckSecurity] getter Window (unsigned long index);
- [Custom, NotEnumerable, DoNotCheckSecurity] getter Window (DOMString name);
+ [Custom, NotEnumerable, DoNotCheckSecurity] getter object (DOMString name);
// the user agent
[LogActivity=GetterOnly] readonly attribute Navigator navigator;
@@ -74,14 +77,15 @@
void alert();
void alert(DOMString message);
boolean confirm(optional DOMString message = "");
- DOMString? prompt(optional DOMString message = "",
- optional DOMString defaultValue = "");
+ DOMString? prompt(optional DOMString message = "", optional DOMString defaultValue = "");
void print();
+ // FIXME: requestAnimationFrame should take a FrameRequestCallback:
+ // https://www.w3.org/Bugs/Public/show_bug.cgi?id=28152
[MeasureAs=UnprefixedRequestAnimationFrame] long requestAnimationFrame(RequestAnimationFrameCallback callback);
- void cancelAnimationFrame(long id);
+ void cancelAnimationFrame(long handle);
- [DoNotCheckSecurity, Custom, RaisesException] void postMessage(SerializedScriptValue message, DOMString targetOrigin, optional sequence<Transferable> transfer);
+ [DoNotCheckSecurity, Custom, RaisesException] void postMessage(any message, DOMString targetOrigin, optional sequence<Transferable> transfer);
// HTML obsolete features
// https://html.spec.whatwg.org/#Window-partial
@@ -90,8 +94,11 @@
// CSS Object Model (CSSOM)
// http://dev.w3.org/csswg/cssom/#extensions-to-the-window-interface
- [TypeChecking=Interface] CSSStyleDeclaration getComputedStyle(Element element, optional DOMString? pseudoElt = null);
+ // FIXME: The optional pseudoElt argument should have no default.
+ [TypeChecking=Interface] CSSStyleDeclaration getComputedStyle(Element elt, optional DOMString? pseudoElt = null);
// http://dev.w3.org/csswg/cssom/#utility-apis
+ // FIXME: CSS should be an interface with static members, in which
+ // case this getter would not be needed.
[Replaceable] readonly attribute CSS CSS;
// CSSOM View Module
@@ -100,12 +107,14 @@
readonly attribute Screen screen;
// browsing context
- void moveTo(optional long x, optional long y); // FIXME: Arguments should not be optional, or should have defaults.
+ // FIXME: The x and y arguments should not be optional. crbug.com/453421
+ void moveTo(optional long x, optional long y);
void moveBy(optional long x, optional long y);
- void resizeTo(optional long width, optional long height); // FIXME: Arguments should not be optional, or should have defaults.
+ void resizeTo(optional long x, optional long y);
void resizeBy(optional long x, optional long y);
// viewport
+ // FIXME: None of the CCSOM View Module attributes should be [Replaceable].
[Replaceable] readonly attribute long innerWidth;
[Replaceable] readonly attribute long innerHeight;
@@ -114,11 +123,11 @@
readonly attribute double pageXOffset;
[Replaceable] readonly attribute double scrollY;
readonly attribute double pageYOffset;
- [RuntimeEnabled=CSSOMSmoothScroll] void scroll([Default=Undefined] optional ScrollToOptions scrollOptions);
+ [RuntimeEnabled=CSSOMSmoothScroll] void scroll(optional ScrollToOptions options);
void scroll(unrestricted double x, unrestricted double y);
- [RuntimeEnabled=CSSOMSmoothScroll] void scrollTo([Default=Undefined] optional ScrollToOptions scrollToOptions);
+ [RuntimeEnabled=CSSOMSmoothScroll] void scrollTo(optional ScrollToOptions options);
void scrollTo(unrestricted double x, unrestricted double y);
- [RuntimeEnabled=CSSOMSmoothScroll] void scrollBy([Default=Undefined] optional ScrollToOptions scrollToOptions);
+ [RuntimeEnabled=CSSOMSmoothScroll] void scrollBy(optional ScrollToOptions options);
void scrollBy(unrestricted double x, unrestricted double y);
// client
@@ -130,38 +139,39 @@
// Selection API
// http://w3c.github.io/selection-api/#extensions-to-window-interface
- Selection getSelection();
+ Selection? getSelection();
// Console API (non-standard but widely implemented in some form)
// https://developer.chrome.com/devtools/docs/console-api
[Replaceable] readonly attribute Console console;
// Non-standard APIs
- [Replaceable] readonly attribute Navigator clientInformation;
- [Custom, MeasureAs=WindowEvent, NotEnumerable] attribute Event event;
- boolean find([Default=Undefined] optional DOMString string,
- [Default=Undefined] optional boolean caseSensitive,
- [Default=Undefined] optional boolean backwards,
- [Default=Undefined] optional boolean wrap,
- [Default=Undefined] optional boolean wholeWord,
- [Default=Undefined] optional boolean searchInFrames,
- [Default=Undefined] optional boolean showDialog);
- [Replaceable, MeasureAs=WindowOffscreenBuffering, NotEnumerable] readonly attribute boolean offscreenBuffering;
- [Replaceable] readonly attribute long screenLeft;
- [Replaceable] readonly attribute long screenTop;
+ [MeasureAs=WindowClientInformation, Replaceable] readonly attribute Navigator clientInformation;
+ [MeasureAs=WindowEvent, Custom, NotEnumerable] attribute Event event;
+ [MeasureAs=WindowFind] boolean find([Default=Undefined] optional DOMString string,
+ [Default=Undefined] optional boolean caseSensitive,
+ [Default=Undefined] optional boolean backwards,
+ [Default=Undefined] optional boolean wrap,
+ [Default=Undefined] optional boolean wholeWord,
+ [Default=Undefined] optional boolean searchInFrames,
+ [Default=Undefined] optional boolean showDialog);
+ [MeasureAs=WindowOffscreenBuffering, Replaceable, NotEnumerable] readonly attribute boolean offscreenBuffering;
+ [MeasureAs=WindowScreenLeft, Replaceable] readonly attribute long screenLeft;
+ [MeasureAs=WindowScreenTop, Replaceable] readonly attribute long screenTop;
[MeasureAs=WindowDefaultStatus] attribute DOMString defaultStatus;
- [ImplementedAs=defaultStatus, MeasureAs=WindowDefaultstatus] attribute DOMString defaultstatus;
+ [MeasureAs=WindowDefaultstatus, ImplementedAs=defaultStatus] attribute DOMString defaultstatus;
[MeasureAs=StyleMedia] readonly attribute StyleMedia styleMedia;
[DeprecateAs=GetMatchedCSSRules] CSSRuleList getMatchedCSSRules([Default=Undefined] optional Element element,
[TreatUndefinedAs=NullString, Default=Undefined] optional DOMString? pseudoElement);
// This is the interface orientation in degrees. Some examples are:
// 0 is straight up; -90 is when the device is rotated 90 clockwise;
// 90 is when rotated counter clockwise.
- [RuntimeEnabled=OrientationEvent, MeasureAs=WindowOrientation] readonly attribute long orientation;
+ [MeasureAs=WindowOrientation, RuntimeEnabled=OrientationEvent] readonly attribute long orientation;
[DeprecateAs=PrefixedRequestAnimationFrame] long webkitRequestAnimationFrame(RequestAnimationFrameCallback callback);
[DeprecateAs=PrefixedCancelAnimationFrame, ImplementedAs=cancelAnimationFrame] void webkitCancelAnimationFrame(long id);
[DeprecateAs=PrefixedCancelRequestAnimationFrame, ImplementedAs=cancelAnimationFrame] void webkitCancelRequestAnimationFrame(long id);
[MeasureAs=PrefixedTransitionEventConstructor] attribute TransitionEventConstructor WebKitTransitionEvent;
+ // FIXME: Reverse this to make WebKitAnimationEvent an alias of AnimationEvent instead.
[RuntimeEnabled=CSSAnimationUnprefixed] attribute WebKitAnimationEventConstructor AnimationEvent;
[DeprecateAs=PrefixedWindowURL] attribute URLConstructor webkitURL;
[MeasureAs=PrefixedMutationObserverConstructor] attribute MutationObserverConstructor WebKitMutationObserver;
« no previous file with comments | « Source/core/frame/UseCounter.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698