Debugging the Debugger is one of the highest levels of inception. Before you begin, prepare yourself for a mind-bending trip of self discovery.
Setup the Debugger so that your environment looks like this gif.
If you have any questions, go back to the getting setup instructions.
Lets design a new theme for the debugger, it's not too hard! Our goal here is to style the source tree, editor, and other UI components.
Share your a screenshot of your theme here ! Here's an example camo theme that I designed the other day.
Adding a breakpoint is a critical piece in the inception game... Lets make the debugger do something special when a breakpoint is added.
diff --git a/src/components/Editor/Breakpoint.js b/src/components/Editor/Breakpoint.js
index e1f1afd1..4ab9ef59 100644
--- a/src/components/Editor/Breakpoint.js
+++ b/src/components/Editor/Breakpoint.js
@@ -38,6 +38,8 @@ class Breakpoint extends Component {
addBreakpoint() {
const { breakpoint, editor, selectedSource } = this.props;
+ // => hamster dance
+
// Hidden Breakpoints are never rendered on the client
if (breakpoint.hidden) {
return;
We currently don't have anything awesome as a demo. If you come up with something cool, feel free to share it here and we can add it to the doc!
When the debugger pauses, the fun begins. Here's a gif of what the debugger does normally when it pauses. Your mission if you choose to accept it, is to make it do something truly weird.
Here's a patch to get you started; WhyPaused.js
renders the pause reason into the sidebar, and utils/pause.js
is used in several places to expose the current paused state.
diff --git a/src/components/SecondaryPanes/Frames/WhyPaused.js b/src/components/SecondaryPanes/Frames/WhyPaused.js
index 364a7c76..ee14b4e9 100644
--- a/src/components/SecondaryPanes/Frames/WhyPaused.js
+++ b/src/components/SecondaryPanes/Frames/WhyPaused.js
@@ -48,6 +48,8 @@ export default function renderWhyPaused({ pause }: { pause: Pause }) {
return null;
}
+ console.log("hello from src/components/SecondaryPanes/Frames/WhyPaused.js!");
+
return (
<div className={"pane why-paused"}>
<div>{L10N.getStr(reason)}</div>
diff --git a/src/utils/pause.js b/src/utils/pause.js
index 2b11d247..c4778a36 100644
--- a/src/utils/pause.js
+++ b/src/utils/pause.js
@@ -85,6 +85,8 @@ export function getPauseReason(pauseInfo: Pause): string | null {
return null;
}
+ console.log("hello from src/utils/pause.js!");
+
const reasonType = get(pauseInfo, "why.type", null);
if (!reasons[reasonType]) {
console.log("Please file an issue: reasonType=", reasonType);
Here's the debugger philosophy in a nutshell.
- When you inspect the running debugger app, you're debugging a web app
- The Debugger like other applications has an API to communicate with the browser
- There's no magic here. If you can build a web app, you can hack on the debugger!
- You are the debugger's principal customer. Remember, the customer is always right!
Please let us know if we're missing something zen here.
Now that you've internalized the debugger philosophy, it's time to start putting this wisdom to use.
Share what you know Give a talk in school, work, or a local meetup. I'm willing to bet your audience will not know the debugger is a web app! Write a blog post. We'd be happy to link to it here and it could go a really long way towards helping a newcomer grok the philosophy.