Coder Social home page Coder Social logo

doctrine's Issues

Doctrine throws an error for {function}

Right now, Doctrine throws an error on this:

/**
 * @param {function} foo desc
 */

However, if you capitalize "function", then it's okay:

/**
 * @param {Function} foo desc
 */

This doesn't appear to be a problem with other types ("object" vs. "Object", "string" vs. "String").

Publish new version

Would you mind publishing a new version to npm? The changes so far have covered most of my use cases.

@param tag without type

We're using your excellent doctrine .js library for parsing some jsdoc. We've noticed that leaving out the type from a @param comment prevents it and the rest of the comment from being parsed. The Jsdoc notes http://usejsdoc.org/tags-param.html suggest that the type is optional so we're wondering if this is intentional or perhaps a bug?

Example:

/** Neither of the parameters below, or the returns comment tag, are parsed
 * @param firstparam
 * @param {String} secondparam
 * @return {Number}
 */

The Jsdoc pages also outline a syntax for identifying optional parameters (by surrounding with []) and specifying default values, e.g. @param {String} [optionalparam="defaultvalue"]. Just wondering if you have any plans to support these jsdoc features?

Move from JSLint to ESLint

As discussed @Constellation I think it would be worthwhile changing from JSLint to ESLint once all the rules you were testing for are supported.

Namely I think the only JSLint check that isn't supported that was being used is: eslint/eslint#625

In regards to the other work, I have added in the library and made sufficient changes to pass the default checks.

"Strict" parsing mode?

For ESLint, I really want to know when there's a syntax error in a JSDoc comment (JSDoc will usually error out). Right now, Doctrine silently ignores most errors and continues on to parse the rest. Is it possible to have a mode that throws errors when they occur rather than continuing on? Some examples I'd like to be able to catch:

// double @
/**
 * Description
 * @@param {string} name Param description
 */

// missing closing curly brace
/**
 * Description
 * @param {string name Param description
 * @param {int} foo Bar
 */

decomposition of doctrine.js

Currently it's 1700 lines

I'm looking to possibly reuse this to generate docs for another OS library, however the size of doctrine.js is rather large.
Can it not be broken down, modularised etc to private functions?

Rename sloppy to jsdoc3

Basically doctrine supports Closure compiler tags.
But jsdoc3 tags are useful, so we need to support it.

Currently jsdoc3 style optional param is supported when sloppy flag is on. This is not suitable name. We should rename sloppy to something like jsdoc3.

Missing @param type results in incorrect reporting of param name

If I have a JSDoc comment like this:

/**
 * My desc
 * @param foo Something descriptive
 */

The resulting node is:

{
    "description": "My description",
    "tags": [
        {
            "title": "param",
            "description": "descriptive",
            "type": {
                "type": "NameExpression",
                "name": "foo"
            },
            "name": "Something"
        }
    ]
}

I would have expected it to say that there is no type and that the name is "foo" rather than "something".

According to the JSDoc documentation (http://usejsdoc.org/tags-param.html), when there are no braces, the first identifier should be the parameter name and the rest should be the description.

How to get "class" name

Hi, I just want to ask, how can i get class name... for example, I have file "events" with this:

/**
 * A base class for event objects, so that they can support preventDefault and
 * stopPropagation.
 *
 * @param {string} type Event Type.
 * @param {Object=} opt_target Reference to the object that is the target of
 *     this event. It has to implement the {@code EventTarget} interface
 *     declared at {@link http://developer.mozilla.org/en/DOM/EventTarget}.
 * @constructor
 */
goog.events.Event = function(type, opt_target) { 
  //...
}

It's nice to have json with informations from jsdoc, but is there any way to get "goog.events.Event" name?

Wrong detected tags in description

/**
 * Prevents the default action. It is equivalent to
 * {@code e.preventDefault()}, but can be used as the callback argument of
 * {@link goog.events.listen} without declaring another function.
 * @param {!goog.events.Event} e An event.
 */
goog.events.Event.preventDefault = function(e) {
  e.preventDefault();
};

is evaluated as:

{
    "description": "/**\nPrevents the default action. It is equivalent to\n{",
    "tags": [
        {
            "title": "code",
            "description": "e.preventDefault()}, but can be used as the callback argument of\n{@link goog.events.listen} without declaring another function."
        },
        {
            "title": "param",
            "description": "An event.\n/\ngoog.events.Event.preventDefault = function(e) {\ne.preventDefault();\n};",
            "type": {
                "type": "NonNullableType",
                "expression": {
                    "type": "NameExpression",
                    "name": "goog.events.Event"
                },
                "prefix": true
            },
            "name": "e"
        }
    ]
}

First three lines should be considered as description

Last tag always has \n in the description

Hi,

the unwrap: true option fails to strip the last new line before */, so an empty description on the last tag in the comment always becomes '/' (not sure why) and a non-empty description always has a newline at the end.

In my code, I have to do this to remove spaces/newlines from before the end of the comment, before passing the comment to doctrine.

 comment = comment.replace(/[\s\n]*\*\/[\s\n]*$/, '*/');

Thanks

Some multiline tags support please?

Is there possibility to add multiline parsing of some tags? Or just param tag?

Test case:

var jsdoc = ['/**', 'Info', '@param {', '  {status: ?boolean},', '  {hint: ?boolean}', '} [condition] some info about ', 'condition param', '@param {boolean} yes'].join('\n * ')+'\n */';
console.log(jsdoc);
require('doctrine').parse(jsdoc, {unwrap:true});

And no tags ;-(

/**
 * Info
 * @param {
 *   {status: ?boolean},
 *   {hint: ?boolean}
 * } [condition] some info about
 * condition param
 * @param {boolean} yes
 */
{ description: 'Info', tags: [] }

Problem is here: jscs-dev/node-jscs#245

Release new version of doctrine

ESLint is throwing errors on @constructor it seems the last release was 11 days ago and that tag was added 10 days ago. So it needs a new version of Doctrine with that tag supported. Thank you.

/*eslint valid-jsdoc:2*/

    /**
     * Responsible for launching Limit Order tickets in a dialog.
     *
     * @constructor
     * @extends caplin.trading.ticket.TicketLauncher
     */
    function MyCons(){
    "use strict";
    }

lineNumbers doesn't provided in throws

doctrine.parse('@param ', {strict: true, lineNumbers: true})

throws

{ name: 'DoctrineError', message: 'Braces are not balanced' }

Can exceptions have location (at least line, but better column) of an error?

Is it possible to create custom tags?

I admit I have not tried this, but since documentation and jsdoc do not mention this, I thought I should ask.

I just want to define a custom @tag and get rest of the line from doctrine as string. I know the library does this with predefined tags, but is it exposed somehow to be extended?

Thanks

Support inline tags

JSDoc has several inline tags that can appear as part of a description. For example: http://usejsdoc.org/tags-link.html

It would be good to represent this in some way in Doctrine, especially if they appear to be a syntax error, such as:

/**
 * Hello {@link world!
 */

Document options

It looks like the parse() method accepts an options object as a second argument, but it's hard to tell what the possible options are from looking at the source code. Can you add some documentation for this?

Lack of name for @augments and @alias

I'm not sure if name is the right property name however @augments and @alias however the values supplied for the augmented name and alias name are filtered into the description property.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.