Research
Security News
Malicious npm Package Targets Solana Developers and Hijacks Funds
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
coffeedoc-lm
Advanced tools
Fork of CoffeeDoc by Larry Maccherone - an API documentation generator for CoffeeScript
CoffeeDoc is a simple API documentation generator for CoffeeScript. It reads python-style docstrings in your CoffeeScript class and function definitions, passes them through Markdown, and outputs the result as easy to read HTML.
CoffeeDoc is inspired by the excellent Docco, and is intended for projects that require more structured API documentation.
The docstring convention CoffeeDoc uses is inspired by Python, and looks like this:
###
# CoffeeDoc example documentation #
This is a module-level docstring, and will be displayed at the top of the module documentation.
Documentation generated by [CoffeeDoc](http://github.com/omarkhan/coffeedoc)
###
class MyClass extends Superclass
###
This docstring documents MyClass. It can include *Markdown* syntax,
which will be converted to html.
###
constructor: (@args) ->
### Constructor documentation goes here. ###
method: (args) ->
### This is a method of MyClass ###
myFunc = (arg1, arg2, args...) ->
###
This function will be documented by CoffeeDoc
###
doSomething()
The documentation generated from the above script can be seen
here. For a more
interesting example, here is the result of running coffeedoc against
src/coffeedoc.coffee
.
CoffeeDoc requires Node.js, CoffeeScript, and eco. Install using npm with the following command:
sudo npm install -g coffeedoc-lm
The -g option installs CoffeeDoc globally, adding the coffeedoc executable to your PATH. If you would rather install locally, omit the -g option.
You can also install from source using cake. From the source directory, run:
sudo cake install
CoffeeDoc can be run from the command line:
Usage: coffeedoc [options] [targets]
Options:
-o, --output: Set output directory (default: ./docs)
--commonjs : Use if target scripts use CommonJS for module loading (default)
--requirejs : Use if target scripts use RequireJS for module loading
--readme : Generates a draft README.md from the module docstrings
-r, --rout : Set output file for README.md (defaults to stdout)
If [targets] is a directory, CoffeeDoc will recursively document all .coffee
files found under that directory.
If you wish to document several modules, make sure you generate all
the docs with a single command -- this ensures that they will all appear in the
index.html
file.
Note that since coffeedoc is intended to document the public API, any functions or
methods that begin with underscore (_
) will be omitted from the generated docs.
Markdown uses #
characters for headers, e.g.
# Header 1
## Header 2
### Header 3
#### Header 4
##### Header 5
###### Header 6
As using a sequence of 3 or more #
characters within a CoffeeScript block
comment would end the comment block, CoffeeDoc allows for the \#
escape
sequence in docstrings. So instead of ### Header
, use \#\#\# Header
or
##\# Header
. Ugly, but it works.
CoffeeDoc uses the CoffeeScript parser to generate a parse tree for the given source files. It then extracts the relevant information from the parse tree: class and function names, class member functions, function argument lists and docstrings.
Docstrings are defined as the first herecomment block following the class or function definition. Note that regular single line comments will be ignored. Docstrings are passed through Showdown, a javascript port of Markdown (CoffeeDoc uses jashkenas' modified version of Showdown used in Docco).
The resulting documentation information is then passed to an eco template to generate the html output.
CoffeeDoc is © 2011 Omar Khan, released under the MIT licence. Use it, fork it.
FAQs
Fork of CoffeeDoc by Larry Maccherone - an API documentation generator for CoffeeScript
The npm package coffeedoc-lm receives a total of 2 weekly downloads. As such, coffeedoc-lm popularity was classified as not popular.
We found that coffeedoc-lm demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.