Skip to content

Latest commit

 

History

History
320 lines (223 loc) · 17.1 KB

CONTRIBUTING.md

File metadata and controls

320 lines (223 loc) · 17.1 KB

Contributing to debugger.html

👍🎉 First off, thanks for taking the time to contribute! 🎉👍

We respect your time and want to help you make the most of it as you learn more about this project.

Getting Started

The developer tools in most major browsers are just web applications. They are HTML & JS rendered by the browser and talk to the browser itself through an API that gives access to the page internals. This project is a brand new web application interface for JavaScript debugging designed for browsers and JS environments.

We strive for collaboration with mutual respect for each other. Mozilla also has a set of participation guidelines which goes into greater detail specific to Mozilla employees and contributors.

About Us

debugger.html is an Open Source Mozilla Firefox Developer Tools project. Our goal is to work with the community to build a universal JS debugger for modern times.

Jason Harald Yulia Victoria David

@jasonlaster

@digitarald

@codehag

@violasong

@darkwing

❤️ Community Team ❤️

Our Community Team is group of dedicated, and talented people who contribute (much needed) maintainer and leadership skills to debugger.html project. They care deeply about the success of everyone who gets involved. To learn more about how their role, and ways they can support your success, checkout out Community Team Page!

You can also find them on the #community-team Slack channel.

How Can I Contribute?

There are lots of ways to contribute to Debugger!

Here is a great GitHub guide on contributing to Open Source to help you get started.

Reporting Bugs 🐛

If you find an issue with the code, please do file an issue. We'll do our best to review the issue in a timely manner and respond.

We will also tag it with the label bug.

Suggesting Enhancements 🆕

We are actively investigating ways of support enhancement requests in the project, so these instructions are subject to change. For now please create an issue, and we will attempt to respond.

We will also tag it with the label enhancement.

Writing Documentation 📖

Documentation is as important as code and we need your help to maintain clear and usable documentation. If you find an error in here or other project documentation, please file an issue.

We will tag it with the label docs.

Give a Talk 💬

The best thing about giving a talk on the debugger is that you can demo debugging the debugger and watch a roomful of minds explode.

The best talks can be as simple as walking through how the debugger works and adding a small feature. For the audience in the room, this will likely be the first time they've seen the internals of a developer tool.

Of course, feel free to ask questions in slack or share talk slides or videos in channel our #talks channel.

Write a Blog Post ✏️

Our primary goal is to help developers understand they have the skills to improve their environment. Writing about DevTools is the best way to dispel the myth that what we do is magic.

Writing is a great way to share what you learn and articulate your passion. Blog posts can either be technical "how x works" or narrative "how we built x". The most important piece is that it helps people feel welcome.

If you would like to write a post and have questions ask one of us in slack. Also, of course share what you've written in slack! Here are some examples search boxes, getting into the flow, better source maps, stepping debugger.

Organize a meetup 🍺

Open source workshops are a great way to bring people together and contribute. The best thing about workshops is that it's the best way for newcomers to make their first PR. It's also a lot of fun!

There's been four workshops so far. Two in New York, one in Tel Aviv, and one in Vancouver. The workshops have helped close to 100 people get started. In all of the cases, the workshop was organized in collaboration with a local meetup group that was interested in promoting open source.

Feel free to reach out to us on slack if you're interested in organizing one. Here is a guide and example document. Amit's goodness squad is a must read.

Give a talk or write a blog post and help others get started. Very few developers know that the debugger is a web app. It's a lot of fun to hear the amazing tools others want to build once they learn that they can!

Getting Started 🏃

Getting started on an open source project is like starting a new job. Expect to spend the first day learning the codebase and meeting the team.

The best thing to do first is to answer specific questions like: "how are sources shown on the left?". Here is a guided activity to help you get started.

It's also helpful to think about who is working on the Debugger and people you might want to ask for help early on. We are lucky to have lots of nice people here.

Your First Code Contribution

If you're looking for a good issue, you can look through the 👋 good first issue and 👋 help wanted issues.

These issues should be well documented.

To begin your work make sure you follow these steps:

Coding Standards

Be consistent with the rest of the code in the file

Here are pointers to the DevTools general coding style and formatting guidelines.

Development Guide 💻

Go to local Development to learn about:

Terminology

Debugging Firefox

At some point, you'll want to debug firefox to see your changes in the devtools panel or inspect the debugger server.

Here's a guide to help you get started guide

Issues

Pull Requests

Go to Pull Requests to learn about:

Working on your first Pull Request? You can learn how from this free series How to Contribute to an Open Source Project on GitHub

Maintainer Tips

Helping maintain a project is the best way to contribute to its overall health. Here are some notes on how we work.

Debugging Tips

Pro Tips

Here are some tips from our contributors.

  • Time management is really important. Try your best to balance obligations.
  • Communicate Communicate early and often. Share your work often and try to land the smallest possible pieces.
  • Goals It's helpful to set realistic goals.
  • Work Consider talking with your manager about OSS time at work. There are several reasons why this makes sense for your employer:
    • expertise teams benefit from having a resident expert on debugging or other tools
    • marketing your manager can market their team as OSS friendly to candidates and other employees.
    • career development the skills you learn in OSS translate to your own growth.
    • sponsoring your team benefits from having quality OSS tools. Sponsoring your OSS time is a great way to give back.

Project Overview

debugger.html

The debugger.html project is a JavaScript debugger built from the ground up using modern web application technologies. It is designed first for debugging Firefox but also for working with projects like Chrome and Node. The name debugger.html was chosen because this debugger interface is being written using modern web technologies where as the previous Firefox debugger was written in XUL.

devtools.html

devtools.html is the larger umbrella initiative that encompasses the debugger.html and several other devtools projects. The devtools.html project claims its origin from a demo for a Mozilla (Dec 2015) work week in Orlando, FL USA where the team worked under a tight deadline to provide a proof of concept of the Firefox developer tools running in pure HTML; even outside of Firefox. The code for that demo can be found on GitHub under @joewalker/devtools.html.

From that original demo the devtools.html project has progressed quite a bit. To learn more about it please read the devtools.html proposal document and take a look at the devtools.html meta bug for tracking progress.

Firefox Developer Tools

The debugger.html project is targeted to land in Firefox for Firefox 52. However if you're looking to work directly on the DevTools project which ships developer tools for Firefox and Firefox Developer Edition right now you can find more information on the Mozilla wiki DevTools / Get Involved.

Talks, Videos, Blog posts

Joining Mozilla

Mozilla has and continues to hire many people from within the Open Source Software community, bringing contributors directly into the team; however contribution is not necessarily a path to employment. Our internal hiring criteria is about more than contributions, we are also looking at a number of other factors that create a diverse and healthy team.

Ask. Take a look at the current openings in https://careers.mozilla.org/ to see if there is a good fit for you. If you’re interested in a job with Mozilla feel free to ask employees what it’s like to work here. However employees can’t help you get hired outside of being a referral for you.

Referrals. If you’ve been making reasonable and regular contributions to the project we’d be happy to be a reference for you. We can make internal referrals to Mozilla or act as your reference to other companies. Please be considerate when making this request, we are happy to help you and want to see you find a job you want but can’t do this for everyone who contributes.