forked from mirrors/gecko-dev
		
	 e5497b955e
			
		
	
	
		e5497b955e
		
	
	
	
	
		
			
			For review purposes, the important changes are in dom/bindings/Configuration.py
and dom/bindings/parser.
The changes to the IDL files were done by running these in dom/webidl
and dom/bindings/test:
  perl -pi -e 's/^interface ([A-Za-z0-9_]+)($| [:{])/[Exposed=Window]\ninterface \1\2/' *.webidl
  perl -pi -e 'BEGIN { $/ = undef; } s/\[HTMLConstructor\]\n\[Exposed=Window\]/[HTMLConstructor,\n Exposed=Window]/g' *.webidl
  perl -pi -e 'BEGIN { $/ = undef; } s/\[NoInterfaceObject\]\n\[Exposed=Window\]/[NoInterfaceObject,\n Exposed=Window]/g' *.webidl
  perl -pi -e 'BEGIN { $/ = undef; } s/\[ChromeOnly\]\n\[Exposed=Window\]/[ChromeOnly,\n Exposed=Window]/g' *.webidl
And running this in dom/chrome-webidl:
  perl -pi -e 'BEGIN { $/ = undef; } s/\[ChromeOnly\]\ninterface/[ChromeOnly, Exposed=Window]\ninterface/g' *.webidl
and then fixing all the resulting parser failures.  I then verified that the
generated code is the same as before this change.
Differential Revision: https://phabricator.services.mozilla.com/D46697
--HG--
extra : moz-landing-system : lando
		
	
			
		
			
				
	
	
		
			60 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| /* -*- 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/.
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * This file declares data structures used to communicate checkerboard reports
 | |
|  * from C++ code to about:checkerboard (see bug 1238042). These dictionaries
 | |
|  * are NOT exposed to standard web content.
 | |
|  */
 | |
| 
 | |
| enum CheckerboardReason {
 | |
|   "severe",
 | |
|   "recent"
 | |
| };
 | |
| 
 | |
| // Individual checkerboard report. Contains fields for the severity of the
 | |
| // checkerboard event, the timestamp at which it was reported, the detailed
 | |
| // log of the event, and the reason this report was saved (currently either
 | |
| // "severe" or "recent").
 | |
| dictionary CheckerboardReport {
 | |
|   unsigned long severity;
 | |
|   DOMTimeStamp timestamp; // milliseconds since epoch
 | |
|   DOMString log;
 | |
|   CheckerboardReason reason;
 | |
| };
 | |
| 
 | |
| // The guard function only allows creation of this interface on the
 | |
| // about:checkerboard page, and only if it's in the parent process.
 | |
| [Func="mozilla::dom::CheckerboardReportService::IsEnabled",
 | |
|  Exposed=Window]
 | |
| interface CheckerboardReportService {
 | |
|   constructor();
 | |
| 
 | |
|   /**
 | |
|    * Gets the available checkerboard reports.
 | |
|    */
 | |
|   sequence<CheckerboardReport> getReports();
 | |
| 
 | |
|   /**
 | |
|    * Gets the state of the apz.record_checkerboarding pref.
 | |
|    */
 | |
|   boolean isRecordingEnabled();
 | |
| 
 | |
|   /**
 | |
|    * Sets the state of the apz.record_checkerboarding pref.
 | |
|    */
 | |
|   void setRecordingEnabled(boolean aEnabled);
 | |
| 
 | |
|   /**
 | |
|    * Flush any in-progress checkerboard reports. Since this happens
 | |
|    * asynchronously, the caller may register an observer with the observer
 | |
|    * service to be notified when this operation is complete. The observer should
 | |
|    * listen for the topic "APZ:FlushActiveCheckerboard:Done". Upon receiving
 | |
|    * this notification, the caller may call getReports() to obtain the flushed
 | |
|    * reports, along with any other reports that are available.
 | |
|    */
 | |
|   void flushActiveReports();
 | |
| };
 |