Skip to content

Commit

Permalink
Patch 0.9.3 (#53)
Browse files Browse the repository at this point in the history
* Properly trigger dynamic config build
   Based on:
   * explicit --parse-config flag
   * passing of any --var during a config build
   * existence of Liquid tags in config file

* Add Liquid detection proc; returns true if Liquid tags found

* Stop passing Jekyll config params over CLI
  Pass config-based Jekyll arguments to jekyll as a Jekyll config file instead of over CLI

* Version bump
  • Loading branch information
briandominick authored Sep 7, 2018
1 parent 1b599d8 commit b26c1f9
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 8 deletions.
29 changes: 22 additions & 7 deletions lib/liquidoc.rb
Original file line number Diff line number Diff line change
Expand Up @@ -73,22 +73,24 @@
# Establish source, template, index, etc details for build jobs from a config file
def config_build config_file, config_vars={}, parse=false
@logger.debug "Using config file #{config_file}."
if config_vars or parse
validate_file_input(config_file, "config")
if config_vars.length > 0 or parse or contains_liquid(config_file)
@logger.debug "Config_vars: #{config_vars.length}"
# If config variables are passed on the CLI, we want to parse the config file
# and use the parsed version for the rest fo this routine
config_out = "#{@build_dir}/pre/#{File.basename(config_file)}"
liquify(nil,config_file, config_out, config_vars)
config_file = config_out
@logger.debug "Config parsed! Using #{config_out} for build."
validate_file_input(config_file, "config")
end
validate_file_input(config_file, "config")
begin
config = YAML.load_file(config_file)
rescue
rescue Exception => ex
unless File.exists?(config_file)
@logger.error "Config file #{config_file} not found."
else
@logger.error "Problem loading config file #{config_file}. Exiting."
@logger.error "Problem loading config file #{config_file}. #{ex} Exiting."
end
raise "ConfigFileError"
end
Expand Down Expand Up @@ -176,6 +178,16 @@ def validate_config_structure config
# TODO More validation needed
end

def contains_liquid filename
File.open(filename, "r") do |file_proc|
file_proc.each_line do |row|
if row.match(/.*\{\%.*\%\}.*|.*\{\{.*\}\}.*/)
return true
end
end
end
end

def explainer_init out=nil
unless @explainer
if out == "STDOUT"
Expand Down Expand Up @@ -931,12 +943,15 @@ def generate_site doc, build
File.open("#{@build_dir}/pre/_attributes.yml", 'w') { |file| file.write(attrs_yaml) }
build.add_config_file("#{@build_dir}/pre/_attributes.yml")
config_list = build.prop_files_array.join(',') # flatten the Array back down for the CLI
opts_args = ""
quiet = "--quiet" if @quiet || @explicit
if build.props['arguments']
opts_args = build.props['arguments'].to_opts_args
opts_args_file = "#{@build_dir}/pre/jekyll_opts_args.yml"
opts_args = build.props['arguments']
File.open(opts_args_file, 'w') { |file|
file.write(opts_args.to_yaml)}
config_list << ",#{opts_args_file}"
end
base_args = "--config #{config_list} #{opts_args}"
base_args = "--config #{config_list}"
command = "bundle exec jekyll build #{base_args} #{quiet}"
if @search_index
# TODO enable config-based admin api key ingest once config is dynamic
Expand Down
2 changes: 1 addition & 1 deletion lib/liquidoc/version.rb
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
module Liquidoc
VERSION = "0.9.2"
VERSION = "0.9.3"
end

0 comments on commit b26c1f9

Please sign in to comment.