# -*- coding: utf-8 -*- # # Copyright 2013 whiteleaf. All rights reserved. # require "fileutils" require_relative "../downloader" require_relative "../inspector" require_relative "../novelsetting" require_relative "../inventory" module Command class Inspect < CommandBase def self.oneline_help "小説状態の調査状況ログを表示します" end def initialize super("[ ...]") @opt.separator <<-EOS ・引数を指定しなかった場合は直前に変換した小説の状態調査状況ログを表示します。 ・小説を指定した場合はその小説のログを表示します。 ・narou setting convert.inspect=true とすれば変換時に常に表示されるようになります。 Examples: narou inspect # 直前の変換時のログを表示 narou inspect 6 # ログを表示したい小説を指定する EOS end def execute(argv) super if argv.empty? latest_id = Inventory.load("latest_convert", :local)["id"] if latest_id data = Downloader.get_data_by_target(latest_id) display_log(data["title"]) end return end tagname_to_ids(argv) argv.each_with_index do |target, i| Helper.print_horizontal_rule if i > 0 data = Downloader.get_data_by_target(target) unless data error "#{target} は存在しません" next end display_log(data["title"]) end end def display_log(title) puts "(#{title} の小説状態調査状況ログ)" novel_setting = NovelSetting.load(title, false, false) puts Inspector.read_messages(novel_setting) || "調査ログがまだ無いようです" end end end