require 'logger' require 'stringio' module AsciiBinder module Helpers BUILD_FILENAME = '_build_cfg.yml' TOPIC_MAP_FILENAME = '_topic_map.yml' DISTRO_MAP_FILENAME = '_distro_map.yml' PREVIEW_DIRNAME = '_preview' PACKAGE_DIRNAME = '_package' STYLESHEET_DIRNAME = '_stylesheets' JAVASCRIPT_DIRNAME = '_javascripts' IMAGE_DIRNAME = '_images' BLANK_STRING_RE = Regexp.new('^\s*$') ID_STRING_RE = Regexp.new('^[A-Za-z0-9\-\_]+$') URL_STRING_RE = Regexp.new('^https?:\/\/[\S]+$') def valid_id?(check_id) return false unless check_id.is_a?(String) return false unless check_id.match ID_STRING_RE return true end def valid_string?(check_string) return false unless check_string.is_a?(String) return false unless check_string.length > 0 return false if check_string.match BLANK_STRING_RE return true end def valid_url?(check_string) return false unless valid_string?(check_string) return false unless check_string.match URL_STRING_RE return true end def camelize(text) text.gsub(/[^0-9a-zA-Z ]/i, '').split(' ').map{ |t| t.capitalize }.join end def git_root_dir @git_root_dir ||= `git rev-parse --show-toplevel`.chomp end def gem_root_dir @gem_root_dir ||= File.expand_path("../../../", __FILE__) end def set_docs_root_dir(docs_root_dir) AsciiBinder.const_set("DOCS_ROOT_DIR", docs_root_dir) end def docs_root_dir AsciiBinder::DOCS_ROOT_DIR end def set_depth(user_depth) AsciiBinder.const_set("DEPTH", user_depth) end def set_log_level(user_log_level) AsciiBinder.const_set("LOG_LEVEL", log_levels[user_log_level]) end def log_levels @log_levels ||= { :debug => Logger::DEBUG.to_i, :error => Logger::ERROR.to_i, :fatal => Logger::FATAL.to_i, :info => Logger::INFO.to_i, :warn => Logger::WARN.to_i, } end def logerr @logerr ||= begin logger = Logger.new(STDERR, level: AsciiBinder::LOG_LEVEL) logger.formatter = proc do |severity, datetime, progname, msg| "#{severity}: #{msg}\n" end logger end end def logstd @logstd ||= begin logger = Logger.new(STDOUT, level: AsciiBinder::LOG_LEVEL) logger.formatter = proc do |severity, datetime, progname, msg| severity == 'ANY' ? "#{msg}\n" : "#{severity}: #{msg}\n" end logger end end def log_info(text) logstd.info(text) end def log_warn(text) logstd.warn(text) end def log_error(text) logerr.error(text) end def log_fatal(text) logerr.fatal(text) end def log_debug(text) logstd.debug(text) end def log_unknown(text) logstd.unknown(text) end def without_warnings verboseness_level = $VERBOSE $VERBOSE = nil yield ensure $VERBOSE = verboseness_level end def template_renderer @template_renderer ||= TemplateRenderer.new(docs_root_dir, template_dir) end def template_dir @template_dir ||= File.join(docs_root_dir,'_templates') end def preview_dir @preview_dir ||= begin lpreview_dir = File.join(docs_root_dir,PREVIEW_DIRNAME) if not File.exists?(lpreview_dir) Dir.mkdir(lpreview_dir) end lpreview_dir end end def package_dir @package_dir ||= begin lpackage_dir = File.join(docs_root_dir,PACKAGE_DIRNAME) if not File.exists?(lpackage_dir) Dir.mkdir(lpackage_dir) end lpackage_dir end end def stylesheet_dir @stylesheet_dir ||= File.join(docs_root_dir,STYLESHEET_DIRNAME) end def javascript_dir @javascript_dir ||= File.join(docs_root_dir,JAVASCRIPT_DIRNAME) end def image_dir @image_dir ||= File.join(docs_root_dir,IMAGE_DIRNAME) end def alias_text(target) "