Coder Social home page Coder Social logo

doctrine's Introduction

NPM version build status Test coverage Downloads Join the chat at https://gitter.im/eslint/doctrine

Doctrine

Doctrine is a JSDoc parser that parses documentation comments from JavaScript (you need to pass in the comment, not a whole JavaScript file).

Deprecation notice

This project is no longer maintained. See the ESLint website for more details.

Installation

You can install Doctrine using npm:

$ npm install doctrine --save-dev

Doctrine can also be used in web browsers using Browserify.

Usage

Require doctrine inside of your JavaScript:

var doctrine = require("doctrine");

parse()

The primary method is parse(), which accepts two arguments: the JSDoc comment to parse and an optional options object. The available options are:

  • unwrap - set to true to delete the leading /**, any * that begins a line, and the trailing */ from the source text. Default: false.
  • tags - an array of tags to return. When specified, Doctrine returns only tags in this array. For example, if tags is ["param"], then only @param tags will be returned. Default: null.
  • recoverable - set to true to keep parsing even when syntax errors occur. Default: false.
  • sloppy - set to true to allow optional parameters to be specified in brackets (@param {string} [foo]). Default: false.
  • lineNumbers - set to true to add lineNumber to each node, specifying the line on which the node is found in the source. Default: false.
  • range - set to true to add range to each node, specifying the start and end index of the node in the original comment. Default: false.

Here's a simple example:

var ast = doctrine.parse(
    [
        "/**",
        " * This function comment is parsed by doctrine",
        " * @param {{ok:String}} userName",
        "*/"
    ].join('\n'), { unwrap: true });

This example returns the following AST:

{
    "description": "This function comment is parsed by doctrine",
    "tags": [
        {
            "title": "param",
            "description": null,
            "type": {
                "type": "RecordType",
                "fields": [
                    {
                        "type": "FieldType",
                        "key": "ok",
                        "value": {
                            "type": "NameExpression",
                            "name": "String"
                        }
                    }
                ]
            },
            "name": "userName"
        }
    ]
}

See the demo page more detail.

Team

These folks keep the project moving and are resources for help:

Contributing

Issues and pull requests will be triaged and responded to as quickly as possible. We operate under the ESLint Contributor Guidelines, so please be sure to read them before contributing. If you're not sure where to dig in, check out the issues.

Frequently Asked Questions

Can I pass a whole JavaScript file to Doctrine?

No. Doctrine can only parse JSDoc comments, so you'll need to pass just the JSDoc comment to Doctrine in order to work.

License

doctrine

Copyright JS Foundation and other contributors, https://js.foundation

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

esprima

some of functions is derived from esprima

Copyright (C) 2012, 2011 Ariya Hidayat (twitter: @ariyahidayat) and other contributors.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  • Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

  • Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

closure-compiler

some of extensions is derived from closure-compiler

Apache License Version 2.0, January 2004 http://www.apache.org/licenses/

Where to ask for help?

Join our Chatroom

doctrine's People

Contributors

alberto avatar arv avatar byk avatar cevou avatar chriswong avatar constellation avatar danez avatar dtao avatar emeegeemee avatar fredj avatar georgewfraser avatar gyandeeps avatar ikokostya avatar jakxz avatar jonathankingston avatar kaicataldo avatar lorefnon avatar maxnordlund avatar medanat avatar mitermayer avatar not-an-aardvark avatar nzakas avatar petebacondarwin avatar platinumazure avatar realityking avatar robloach avatar shinnn avatar teppeis avatar tmcw avatar tschaub avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

doctrine's Issues

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?

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";
    }

@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?

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

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

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?

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.

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?

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

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.

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!
 */

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.

"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
 */

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.

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.

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

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?

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.