Skip to content

Commit

Permalink
Make console a namespace (fixes #13010)
Browse files Browse the repository at this point in the history
  • Loading branch information
nox committed Sep 10, 2016
1 parent 0b689a8 commit 2bc0862
Show file tree
Hide file tree
Showing 9 changed files with 30 additions and 73 deletions.
65 changes: 21 additions & 44 deletions components/script/dom/console.rs
Expand Up @@ -4,38 +4,17 @@

use devtools_traits::{ConsoleMessage, LogLevel, ScriptToDevtoolsControlMsg};
use dom::bindings::cell::DOMRefCell;
use dom::bindings::codegen::Bindings::ConsoleBinding;
use dom::bindings::codegen::Bindings::ConsoleBinding::ConsoleMethods;
use dom::bindings::global::GlobalRef;
use dom::bindings::js::Root;
use dom::bindings::reflector::{Reflectable, Reflector, reflect_dom_object};
use dom::bindings::str::DOMString;
use std::collections::HashMap;
use std::collections::hash_map::Entry;
use time::{Timespec, get_time};

// https://developer.mozilla.org/en-US/docs/Web/API/Console
#[dom_struct]
pub struct Console {
reflector_: Reflector,
}
pub struct Console(());

impl Console {
fn new_inherited() -> Console {
Console {
reflector_: Reflector::new(),
}
}

pub fn new(global: GlobalRef) -> Root<Console> {
reflect_dom_object(box Console::new_inherited(),
global,
ConsoleBinding::Wrap)
}

fn send_to_devtools(&self, level: LogLevel, message: DOMString) {
let global = self.global();
let global = global.r();
fn send_to_devtools(global: GlobalRef, level: LogLevel, message: DOMString) {
if let Some(chan) = global.devtools_chan() {
let console_message = prepare_message(level, message);
let devtools_message = ScriptToDevtoolsControlMsg::ConsoleAPI(
Expand All @@ -47,75 +26,73 @@ impl Console {
}
}

impl ConsoleMethods for Console {
impl Console {
// https://developer.mozilla.org/en-US/docs/Web/API/Console/log
fn Log(&self, messages: Vec<DOMString>) {
pub fn Log(global: GlobalRef, messages: Vec<DOMString>) {
for message in messages {
println!("{}", message);
self.send_to_devtools(LogLevel::Log, message);
Self::send_to_devtools(global, LogLevel::Log, message);
}
}

// https://developer.mozilla.org/en-US/docs/Web/API/Console
fn Debug(&self, messages: Vec<DOMString>) {
pub fn Debug(global: GlobalRef, messages: Vec<DOMString>) {
for message in messages {
println!("{}", message);
self.send_to_devtools(LogLevel::Debug, message);
Self::send_to_devtools(global, LogLevel::Debug, message);
}
}

// https://developer.mozilla.org/en-US/docs/Web/API/Console/info
fn Info(&self, messages: Vec<DOMString>) {
pub fn Info(global: GlobalRef, messages: Vec<DOMString>) {
for message in messages {
println!("{}", message);
self.send_to_devtools(LogLevel::Info, message);
Self::send_to_devtools(global, LogLevel::Info, message);
}
}

// https://developer.mozilla.org/en-US/docs/Web/API/Console/warn
fn Warn(&self, messages: Vec<DOMString>) {
pub fn Warn(global: GlobalRef, messages: Vec<DOMString>) {
for message in messages {
println!("{}", message);
self.send_to_devtools(LogLevel::Warn, message);
Self::send_to_devtools(global, LogLevel::Warn, message);
}
}

// https://developer.mozilla.org/en-US/docs/Web/API/Console/error
fn Error(&self, messages: Vec<DOMString>) {
pub fn Error(global: GlobalRef, messages: Vec<DOMString>) {
for message in messages {
println!("{}", message);
self.send_to_devtools(LogLevel::Error, message);
Self::send_to_devtools(global, LogLevel::Error, message);
}
}

// https://developer.mozilla.org/en-US/docs/Web/API/Console/assert
fn Assert(&self, condition: bool, message: Option<DOMString>) {
pub fn Assert(global: GlobalRef, condition: bool, message: Option<DOMString>) {
if !condition {
let message = message.unwrap_or_else(|| DOMString::from("no message"));
println!("Assertion failed: {}", message);
self.send_to_devtools(LogLevel::Error, message);
Self::send_to_devtools(global, LogLevel::Error, message);
}
}

// https://developer.mozilla.org/en-US/docs/Web/API/Console/time
fn Time(&self, label: DOMString) {
let global = self.global();
if let Ok(()) = global.r().console_timers().time(label.clone()) {
pub fn Time(global: GlobalRef, label: DOMString) {
if let Ok(()) = global.console_timers().time(label.clone()) {
let message = DOMString::from(format!("{}: timer started", label));
println!("{}", message);
self.send_to_devtools(LogLevel::Log, message);
Self::send_to_devtools(global, LogLevel::Log, message);
}
}

// https://developer.mozilla.org/en-US/docs/Web/API/Console/timeEnd
fn TimeEnd(&self, label: DOMString) {
let global = self.global();
if let Ok(delta) = global.r().console_timers().time_end(&label) {
pub fn TimeEnd(global: GlobalRef, label: DOMString) {
if let Ok(delta) = global.console_timers().time_end(&label) {
let message = DOMString::from(
format!("{}: {}ms", label, delta)
);
println!("{}", message);
self.send_to_devtools(LogLevel::Log, message);
Self::send_to_devtools(global, LogLevel::Log, message);
};
}
}
Expand Down
6 changes: 4 additions & 2 deletions components/script/dom/webidls/Console.webidl
Expand Up @@ -9,8 +9,10 @@
* © Copyright 2014 Mozilla Foundation.
*/

[Exposed=(Window,Worker)]
interface Console {
[ClassString="Console",
Exposed=(Window,Worker),
ProtoObjectHack]
namespace console {
// These should be DOMString message, DOMString message2, ...
void log(DOMString... messages);
void debug(DOMString... messages);
Expand Down
1 change: 0 additions & 1 deletion components/script/dom/webidls/Window.webidl
Expand Up @@ -161,7 +161,6 @@ partial interface Window {

// Proprietary extensions.
partial interface Window {
readonly attribute Console console;
void debug(DOMString arg);
void gc();
void trap();
Expand Down
7 changes: 0 additions & 7 deletions components/script/dom/webidls/WorkerGlobalScope.webidl
Expand Up @@ -24,10 +24,3 @@ partial interface WorkerGlobalScope { // not obsolete
};
WorkerGlobalScope implements WindowTimers;
WorkerGlobalScope implements WindowBase64;

// Proprietary
[Exposed=Worker]
partial interface WorkerGlobalScope {
[Replaceable]
readonly attribute Console console;
};
9 changes: 1 addition & 8 deletions components/script/dom/window.rs
Expand Up @@ -25,7 +25,7 @@ use dom::bindings::str::DOMString;
use dom::bindings::structuredclone::StructuredCloneData;
use dom::bindings::utils::{GlobalStaticData, WindowProxyHandler};
use dom::browsingcontext::BrowsingContext;
use dom::console::{Console, TimerSet};
use dom::console::TimerSet;
use dom::crypto::Crypto;
use dom::cssstyledeclaration::{CSSModificationAccess, CSSStyleDeclaration};
use dom::document::Document;
Expand Down Expand Up @@ -157,7 +157,6 @@ pub struct Window {
history_traversal_task_source: HistoryTraversalTaskSource,
#[ignore_heap_size_of = "task sources are hard"]
file_reading_task_source: FileReadingTaskSource,
console: MutNullableHeap<JS<Console>>,
crypto: MutNullableHeap<JS<Crypto>>,
navigator: MutNullableHeap<JS<Navigator>>,
#[ignore_heap_size_of = "channels are hard"]
Expand Down Expand Up @@ -511,11 +510,6 @@ impl WindowMethods for Window {
self.local_storage.or_init(|| Storage::new(&GlobalRef::Window(self), StorageType::Local))
}

// https://developer.mozilla.org/en-US/docs/Web/API/Console
fn Console(&self) -> Root<Console> {
self.console.or_init(|| Console::new(GlobalRef::Window(self)))
}

// https://dvcs.w3.org/hg/webcrypto-api/raw-file/tip/spec/Overview.html#dfn-GlobalCrypto
fn Crypto(&self) -> Root<Crypto> {
self.crypto.or_init(|| Crypto::new(GlobalRef::Window(self)))
Expand Down Expand Up @@ -1704,7 +1698,6 @@ impl Window {
history_traversal_task_source: history_task_source,
file_reading_task_source: file_task_source,
image_cache_chan: image_cache_chan,
console: Default::default(),
crypto: Default::default(),
navigator: Default::default(),
image_cache_thread: image_cache_thread,
Expand Down
9 changes: 1 addition & 8 deletions components/script/dom/workerglobalscope.rs
Expand Up @@ -11,7 +11,7 @@ use dom::bindings::inheritance::Castable;
use dom::bindings::js::{JS, MutNullableHeap, Root};
use dom::bindings::reflector::Reflectable;
use dom::bindings::str::DOMString;
use dom::console::{Console, TimerSet};
use dom::console::TimerSet;
use dom::crypto::Crypto;
use dom::dedicatedworkerglobalscope::DedicatedWorkerGlobalScope;
use dom::eventtarget::EventTarget;
Expand Down Expand Up @@ -79,7 +79,6 @@ pub struct WorkerGlobalScope {
resource_threads: ResourceThreads,
location: MutNullableHeap<JS<WorkerLocation>>,
navigator: MutNullableHeap<JS<WorkerNavigator>>,
console: MutNullableHeap<JS<Console>>,
crypto: MutNullableHeap<JS<Crypto>>,
timers: OneshotTimers,

Expand Down Expand Up @@ -132,7 +131,6 @@ impl WorkerGlobalScope {
resource_threads: init.resource_threads,
location: Default::default(),
navigator: Default::default(),
console: Default::default(),
crypto: Default::default(),
timers: OneshotTimers::new(timer_event_chan, init.scheduler_chan.clone()),
mem_profiler_chan: init.mem_profiler_chan,
Expand Down Expand Up @@ -303,11 +301,6 @@ impl WorkerGlobalScopeMethods for WorkerGlobalScope {
self.navigator.or_init(|| WorkerNavigator::new(self))
}

// https://developer.mozilla.org/en-US/docs/Web/API/WorkerGlobalScope/console
fn Console(&self) -> Root<Console> {
self.console.or_init(|| Console::new(GlobalRef::Worker(self)))
}

// https://html.spec.whatwg.org/multipage/#dfn-Crypto
fn Crypto(&self) -> Root<Crypto> {
self.crypto.or_init(|| Crypto::new(GlobalRef::Worker(self)))
Expand Down
2 changes: 1 addition & 1 deletion tests/wpt/mozilla/tests/mozilla/interfaces.html
Expand Up @@ -27,7 +27,6 @@
"DOMRect",
"DOMRectReadOnly",
"Comment",
"Console",
"CustomEvent",
"Document",
"DocumentFragment",
Expand Down Expand Up @@ -183,5 +182,6 @@
"XMLHttpRequest",
"XMLHttpRequestEventTarget",
"XMLHttpRequestUpload",
"console",
]);
</script>
2 changes: 1 addition & 1 deletion tests/wpt/mozilla/tests/mozilla/interfaces.js
Expand Up @@ -65,7 +65,7 @@ function test_interfaces(interfaceNamesInGlobalScope) {
}

for (var name of Object.getOwnPropertyNames(self)) {
if (!/^[A-Z]/.test(name)) {
if (!/^[A-Z]/.test(name) && name != 'console') {
continue;
}
assert_true(name in interfaceMap,
Expand Down
2 changes: 1 addition & 1 deletion tests/wpt/mozilla/tests/mozilla/interfaces.worker.js
Expand Up @@ -23,7 +23,6 @@ test_interfaces([
"DOMRect",
"DOMRectReadOnly",
"Comment",
"Console",
"CustomEvent",
"DedicatedWorkerGlobalScope",
"Document",
Expand Down Expand Up @@ -128,6 +127,7 @@ test_interfaces([
"XMLHttpRequest",
"XMLHttpRequestEventTarget",
"XMLHttpRequestUpload",
"console",
]);

done();

0 comments on commit 2bc0862

Please sign in to comment.