Sha256: e45a36369078c73b77a443944bef932daa64720cdd2ad0cd3abf2526143ec9ad

Contents?: true

Size: 1.38 KB

Versions: 2

Compression:

Stored size: 1.38 KB

Contents

#!/usr/bin/env ruby

require "graphql-docs"
require "optparse"

NAME = "graphql-docs".freeze

opts = {}
OptionParser.new do |parser|
  parser.program_name = NAME
  parser.banner = <<~EOS

  Generate GraphQL docs from the passed in schema file.

  Usage: graphql-docs SCHEMA

  The only required argument is the path to the schema file to generate the site from.

  Examples:
    $ graphql-docs schema.graphql
    $ graphql-docs schema.graphql -o _docs

  Options:
  EOS

  parser.version = GraphQLDocs::VERSION

  parser.on("-o", "--output-dir DIR", "Where the site is generated to, defaults to ./output")
  parser.on("-d", "--delete-output", "Delete the output-dir before generating, defaults to false")
  parser.on("-b", "--base-url URL", "URL to preprend for assets and links, defaults to \"\"")
  parser.on("-v", "--version", "Show the version")
  parser.on("--verbose", "Run in verbose mode")
end.parse!(into: opts)

if opts[:version]
  puts("v#{GraphQLDocs::VERSION}")
  exit
end

def err(msg)
  abort("#{NAME}: Error: #{msg}")
end

schema = ARGV[0]
if schema.nil?
  err("schema must be specified")
end
opts[:filename] = schema

verbose = opts.delete(:verbose)

puts("Generating site with the following options: #{opts}") if verbose

opts.transform_keys! { |k| k.to_s.gsub("-", "_").to_sym }
GraphQLDocs.build(opts)

puts("Site successfully generated in: #{opts[:output_dir] || 'output' }") if verbose

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
graphql-docs-5.1.0 exe/graphql-docs
graphql-docs-5.0.0 exe/graphql-docs