-
Notifications
You must be signed in to change notification settings - Fork 10.1k
Style Guide
This page outlines the style conventions that PDF.js follows to maintain a consistent codebase. We ask each contributor that creates a pull request to adhere to these conventions.
Many of these conventions will also be checked automatically by a linting tool after each push to a branch of a pull request. Please refer to https://github.com/mozilla/pdf.js/wiki/Contributing#4-run-lint-and-testing for information about running the linting tool locally.
- Indentation: 2 spaces
- Line length: 80 characters
- Required license in header: see https://github.com/mozilla/pdf.js/blob/master/src/license_header.js
- Variables and functions: lowerCamelCase
- Constructor-like functions: UpperCamelCase
- Constants: ALL_UPPER_CASE_WITH_UNDERSCORES
Always use braces and put them on same line, even for single line control statements:
if (someVar) {
return true;
} else {
return null;
}
Keep one space after control statements (if, else, while, for, et cetera):
if (someVar) {
Use only strict equalities (===
) and inequalities (!==
):
if (someVar === conditionA) {
return true;
} else if (someVar !== conditionB) {
return false;
}
Variables must be defined only once within a function scope, preferably at the top of the function.
The transition towards ES6 classes has started, but until that is completed, the standard way of creating classes in PDF.js, when adding new code, is the following. Please note that by class we mean an object that is class-like.
var ClassName = (function ClassNameClosure() {
function ClassName(...) {
...
}
ClassName.prototype = {
functionName: function (arg1, arg2, ...) {
...
},
aVeryVeryVeryLongFunctionName: function (arg1,
arg2,
...) {
...
},
};
return ClassName;
})();