Class: Eco::API::UseCases::Default::Utils::SplitJson

Inherits:
Common::Loaders::UseCase show all
Defined in:
lib/eco/api/usecases/default/utils/split_json_case.rb,
lib/eco/api/usecases/default/utils/cli/split_json_cli.rb

Defined Under Namespace

Classes: Cli

Constant Summary collapse

MAX_ITEMS =
15_000

Instance Attribute Summary

Attributes included from Language::AuxiliarLogger

#logger

Instance Method Summary collapse

Methods inherited from Common::Loaders::UseCase

#cli_apply!, #initialize

Methods included from Common::Loaders::UseCase::CliIdentify

#cli, #cli!

Methods included from Common::Loaders::UseCase::TargetModel

#target_model

Methods included from Common::Loaders::UseCase::Type

#type

Methods inherited from Common::Loaders::CaseBase

#name, name_only_once!, original_name

Methods inherited from Common::Loaders::Base

<=>, created_at, #initialize, set_created_at!

Methods included from Language::Klass::InheritableClassVars

#inheritable_attrs, #inheritable_class_vars, #inherited

Methods included from Language::Klass::Naming

#instance_variable_name, #to_constant

Methods included from Language::Klass::Hierarchy

#descendants, #descendants?

Methods included from Language::Klass::Builder

#new_class

Methods included from Language::Klass::Uid

#uid

Methods included from Language::Klass::Resolver

#class_resolver, #resolve_class

Methods included from Language::Klass::Const

#if_const, #redef_without_warning

Methods included from Language::AuxiliarLogger

#log

Constructor Details

This class inherits a constructor from Eco::API::Common::Loaders::UseCase

Instance Method Details

#main(*_args) ⇒ Object



9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# File 'lib/eco/api/usecases/default/utils/split_json_case.rb', line 9

def main(*_args)
  if simulate?
    count = input_json.count
    log(:info) { "JSON '#{input_file}' has #{count} elements." }
  else
    split_json_into_files!

    msg  = []
    msg << "Total elements: #{total_count}"
    msg << 'Generated files:'
    out_files.each do |file|
      msg << "  * #{file}'"
    end

    log(:info) { msg.join("\n") }
  end
end