When you're documenting an object/method/variable, ask: What would a stranger -- who knows basic coding & a bit about our project -- need to:
- Get or make an instance of this object?
- Use a class or function?
- Edit this code?
The clearer you can make the code itself, the less documentation is needed (see the notes below on avoiding pointless documentation).
But: readable method and variable names alone are not enough to make code self-documenting.
Things to document:
- Assumptions a method makes about the state of things.
- Exceptions that may be thrown, and why.
- Parameters whose meanings aren't obvious from the names. But there is no need to document the obvious.
- Methods that may return null, and why.
- When parameters can be null, and what that means.
- Object lifecycle (i.e. how it is wired up and disposed).
- Typical calling patterns -- how methods fit together.
The SoDash/Winterwell House Style
- Prefaces you might use: 
 - FIXMEfor we-really-should-do-this.
- TODOfor less urgent tasks.
- ??for questions / things your uncertain about.
- NBfor tangential notes, e.g. explaining why you didn't use alternative method X.
 
- You can sign comments tweet-style with ^name or ^initials.
- If you see code whose purpose or behaviour you can't understand, add a comment. E.g. "?? is this number a probability? ^DW April 2014"
- Use assertin java, or SJTest'sassert()andassertMatch()in javascript as a way to simultaneously test & document in-code assumptions.
How not to document
It's not about the amount of JavaDoc / JSDoc. It's the quality. Here's an example of pointless documentation:
/** {Object} */
var displayData;   
/** Get the display data for the part. 
* @param {string} url The url 
* @returns {Object} the display data.
*/
function getDisplayData(part, url)
How weak is this?
- There's no point in doc which just restates the function/variable name. You are not writing for idiots.
- Type {Object} tells us very little! What kind of object is it?
 A common case is where Object is a lookup map, in which case
 say what the keys are. Consider using a name which clearly describes the lookup, e.g.tagsetFromTagis clear, whereas tagsets isn't.
- Parameters: Can they be null? What happens if they are?
- The input parameter urlin this example is ambiguous: is this an absolute url, a relative url, or does it not matter because both will give the same output, or does it matter but which to use is specified elsewhere?
- Return value: can it be null?
- Lifecycle: when can this be called? E.g. does it only make sense after the page has done some initialisation steps.
Photo: Book sculpture by Daniel Lai, "Kenjio"
 
 
No comments:
Post a Comment