Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ctags-prebuilt

Package Overview
Dependencies
Maintainers
2
Versions
11
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ctags-prebuilt

A package for reading source code tag files prebuilt for Mac and Linux

  • 0.2.3
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
4
decreased by-55.56%
Maintainers
2
Weekly downloads
 
Created
Source

ctags-prebuilt

Build Status

Self-sufficient fork of node-tags prebuilt for Mac and Linux. Read all about ctags here.

About

ctags-prebuilt includes prebuilt binaries of node-tags for Mac and Linux for major versions of node.js and io.js. It's meant for use in Atom packages where your end-user might not have a proper build toolchain.

This module isn't meant to be built by the end-user. It doesn't include the necessary files for it.

Building

$ npm version patch
$ git push --follow-tags
# wait for travis to build
$ npm publish

Installing

npm install ctags-prebuilt

Usage in Atom Packages

Atom looks in a package's node_modules for .node files to check for compatibility. Since ctags-prebuilt bundles different binaries that are not compatible with your target platform, it's important that you copy this library into package directory, instead of including in dependencies.

Documentation

findTags(tagsFilePath, tag, [options], callback)

Get all tags matching the tag specified from the tags file at the path.

  • tagsFilePath - The string path to the tags file.

  • tag - The string name of the tag to search for.

  • options - An optional options object containing the following keys:

    • caseInsensitive - true to include tags that match case insensitively, (default: false)
    • partialMatch - true to include tags that partially match the given tag (default: false)
    • limit - maximum number of matches to return. Should be a positive integer. (default: unlimited)
  • callback - The function to call when complete with an error as the first argument and an array containing tag objects. Each tag object contains:

    • name - name of the tag
    • file - location of the tag
    • kind - kind of the tag (see ctags --list-kinds)
    • lineNumber - line number of the tag in file (defaults to 0 if not provided)
    • pattern (optional) - pattern to search for in file (only if provided in tag file)
    • fields (optional) - object with string values; extra fields for the tag (only if provided in tag file)
Example
const ctags = require('ctags');

ctags.findTags('/Users/me/repos/node/tags', 'exists', (error, tags=[]) => {
  for (tag of tags) {
    console.log(`${tag.name} is in ${tag.file}`);
  }
});

createReadStream(tagsFilePath, [options])

Create a read stream to a tags file.

The stream returned will emit data events with arrays of tag objects that have name and file keys and optionally a pattern key if the tag file specified contains tag patterns.

An error event will be emitted if the tag file cannot be read.

An end event will be emitted when all the tags have been read.

  • tagsFilePath - The string path to the tags file.

  • options - An optional object containing the following keys.

    • chunkSize - The number of tags to read at a time (default: 100).

Returns a stream.

Example
const ctags = require('ctags');

const stream = ctags.createReadStream('/Users/me/repos/node/tags');
stream.on('data', (tags) => {
  for (tag of tags) {
    console.log(`${tag.name} is in ${tag.file} with pattern: ${tag.pattern}`);
  }
});

Keywords

FAQs

Package last updated on 17 Nov 2016

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc