mirror of
https://github.com/Hopiu/annotate-extension.git
synced 2026-03-17 00:10:23 +00:00
First commit
This commit is contained in:
commit
ae10bdcb0f
2 changed files with 155 additions and 0 deletions
22
README.md
Executable file
22
README.md
Executable file
|
|
@ -0,0 +1,22 @@
|
|||
Brackets JSDoc Annotate
|
||||
=================
|
||||
|
||||
A brackets extension to generate JSDoc annotations for your functions.
|
||||
|
||||
To install, place the ```annotate``` folder inside the ```brackets/src/extensions/user``` folder.
|
||||
|
||||
Usage
|
||||
=====
|
||||
Open a project in Brackets, place your cursor before a function definition, and select ```Annotate``` form the ```Edit``` menu.
|
||||
|
||||
This will create a JSDoc like annotation according to the function signature. It will add ```@private``` if the function starts with an underscore. It will create a ```@param``` for each parameter.
|
||||
|
||||
|
||||
Known issues
|
||||
=====
|
||||
|
||||
Annotations are not correctly indented.
|
||||
|
||||
It will only work with function declared with the form ```function name ([parameters]) {}```.
|
||||
|
||||
No ```@return``` is generated since the extension only looks at the function signature to generate the annotation, not its body.
|
||||
133
main.js
Normal file
133
main.js
Normal file
|
|
@ -0,0 +1,133 @@
|
|||
/*
|
||||
* Copyright (c) 2012 Adobe Systems Incorporated. All rights reserved.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||
* DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
*/
|
||||
|
||||
/*jslint vars: true, plusplus: true, devel: true, nomen: true, regexp: true, indent: 4, maxerr: 50 */
|
||||
/*global define, $, brackets, window */
|
||||
|
||||
/** extension to generate JSDoc annotations for functions */
|
||||
define(function (require, exports, module) {
|
||||
|
||||
'use strict';
|
||||
|
||||
|
||||
var CommandManager = brackets.getModule("command/CommandManager"),
|
||||
EditorManager = brackets.getModule("editor/EditorManager"),
|
||||
Menus = brackets.getModule("command/Menus");
|
||||
|
||||
|
||||
var EMPTY_MSG = "No function found";
|
||||
var COMMAND_ID = "annotate.annotate";
|
||||
var MENU_NAME = "Annotate function";
|
||||
|
||||
|
||||
function insert(input) {
|
||||
|
||||
|
||||
var editor = EditorManager.getCurrentFullEditor();
|
||||
var pos = editor.getCursorPos();
|
||||
|
||||
var i;
|
||||
var lines = input.split("\n");
|
||||
|
||||
|
||||
for (i = 0; i < lines.length; i++) {
|
||||
|
||||
if (i !== lines.length - 1) {
|
||||
lines[i] = lines[i] + "\n";
|
||||
}
|
||||
|
||||
editor._codeMirror.setLine(pos.line, lines[i]);
|
||||
|
||||
// TODO: indent (looks like code mirror does not indent correctly multiline comments)
|
||||
//editor._codeMirror.indentLine(pos.line);
|
||||
|
||||
pos.line++;
|
||||
}
|
||||
|
||||
EditorManager.focusEditor();
|
||||
|
||||
}
|
||||
|
||||
function _generateComment() {
|
||||
|
||||
var output = "/**\n";
|
||||
|
||||
var editor = EditorManager.getCurrentFullEditor();
|
||||
var pos = editor.getCursorPos();
|
||||
|
||||
// Take the text of the document, starting with the current cursor line
|
||||
var txtFrom = editor._codeMirror.getRange(pos, {line: editor._codeMirror.lineCount() });
|
||||
|
||||
// For now, we generate annotations from the signature only (missing return statements)
|
||||
txtFrom = txtFrom.substr(0, txtFrom.indexOf("{"));
|
||||
|
||||
// Look for words
|
||||
var re = /\w+/g;
|
||||
var results = txtFrom.match(re);
|
||||
|
||||
// The first word found should be "function", and next ones parameters
|
||||
if (results[0] !== "function") {
|
||||
window.alert(EMPTY_MSG);
|
||||
return;
|
||||
}
|
||||
|
||||
// Assume function is private if it starts with an underscore
|
||||
var fname = results[1];
|
||||
if (fname.charAt(0) === "_") {
|
||||
output += " * @private\n";
|
||||
}
|
||||
|
||||
// Add description
|
||||
output += " * Description\n";
|
||||
|
||||
// Add parameters
|
||||
if (results.length > 2) {
|
||||
var i;
|
||||
for (i = 2; i < results.length; i++) {
|
||||
var param = results[i];
|
||||
output += " * @param {type} " + param + " Description\n";
|
||||
}
|
||||
}
|
||||
|
||||
// TODO use if 'return' is found in the function body?
|
||||
//output += " * @return {type} ???\n";
|
||||
output += " */";
|
||||
|
||||
return output;
|
||||
}
|
||||
|
||||
|
||||
function annotate() {
|
||||
|
||||
var comment = _generateComment();
|
||||
insert(comment);
|
||||
}
|
||||
|
||||
|
||||
CommandManager.register(MENU_NAME, COMMAND_ID, annotate);
|
||||
|
||||
var menu = Menus.getMenu(Menus.AppMenuBar.EDIT_MENU);
|
||||
menu.addMenuDivider();
|
||||
menu.addMenuItem("menu-edit-annotate", COMMAND_ID);
|
||||
|
||||
});
|
||||
Loading…
Reference in a new issue