Sha256: f19d2cbf66b3fa5c23ce74f7ec9fd3896b4296a9cd32c4543bde02d5ecdd8887
Contents?: true
Size: 1.92 KB
Versions: 6
Compression:
Stored size: 1.92 KB
Contents
require 'json' require 'inch/language/javascript/provider/jsdoc/object' module Inch module Language module JavaScript module Provider module JSDoc # Parses the source tree (using JSDoc) class Parser # TODO: should we remove constant and namespace from this list? IGNORE_TYPES = %w(event external file interface member mixin package param constant namespace) attr_reader :parsed_objects # Helper method to parse an instance with the given +args+ # # @see #parse # @return [CodeObject::Provider::JSDoc::Parser] the instance that # ran def self.parse(*args) parser = new parser.parse(*args) parser end # @param dir [String] directory # @param config [Inch::Config::Codebase] configuration for codebase # @return [void] def parse(dir, config) raise "Directory does not exist: #{dir}" if !File.exist?(dir) Dir.chdir(dir) do parse_objects(config.included_files, config.excluded_files, config.read_dump_file) end end # @return [Array<YARD::Object::Base>] def objects @objects ||= parsed_objects.map do |o| JSDoc::Object.for(o) unless IGNORE_TYPES.include?(o['kind']) end.compact.uniq end private def parse_objects(_paths, _excluded, read_dump_file = nil) if read_dump_file.nil? fail 'JavaScript analysis only works with --read-from-dump.' else output = File.read(read_dump_file, :encoding => 'utf-8') end @parsed_objects = JSON[output]['objects'] end end end end end end end
Version data entries
6 entries across 6 versions & 1 rubygems