Class: Pindo::Command::Ios::Autobuild
- Inherits:
-
Pindo::Command::Ios
- Object
- CLAide::Command
- Pindo::Command
- Pindo::Command::Ios
- Pindo::Command::Ios::Autobuild
- Defined in:
- lib/pindo/command/ios/autobuild.rb
Constant Summary
Constants inherited from Pindo::Command
DEFAULT_OPTIONS, DEFAULT_ROOT_OPTIONS
Instance Attribute Summary
Attributes inherited from Pindo::Command
Class Method Summary collapse
-
.option_items ⇒ Object
定义此命令使用的参数项(类方法,避免重复定义).
-
.options ⇒ Object
命令的选项列表.
-
.use_cache? ⇒ Boolean
启用缓存机制.
Instance Method Summary collapse
-
#initialize(argv) ⇒ Autobuild
constructor
A new instance of Autobuild.
- #run ⇒ Object
- #validate! ⇒ Object
Methods inherited from Pindo::Command
command_name, #initialize_options, run
Methods included from Funlog::Mixin
Methods included from Pindoconfig::Mixin
Constructor Details
#initialize(argv) ⇒ Autobuild
Returns a new instance of Autobuild.
101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 |
# File 'lib/pindo/command/ios/autobuild.rb', line 101 def initialize(argv) # 先提取 build_type(因为 bundleid 的 value_block 需要用到它) @build_type = argv.option('build_type', 'dev') = (argv) # 保存参数到实例变量 @build_type = [:build_type] || @build_type @args_send_flag = [:send] # send 依赖 upload:如果指定了 send,自动启用 upload @args_upload_flag = [:send] || [:upload] @args_proj_name = [:proj] @args_bundle_id = [:bundleid] # Unity 参数 @args_skip_lib = [:skiplib] || false @args_skip_yoo = [:skipyoo] || false # Git 参数 @args_release_branch = [:release_branch] || 'master' @args_ver_inc = Pindo::Options::GitOptions.parse_version_increase_type([:ver_inc] || 'mini') @args_tag_type = Pindo::Options::GitOptions.parse_create_tag_type([:tag_type] || 'new') @args_tag_pre = [:tag_pre] || 'v' super @additional_args = argv.remainder! end |
Class Method Details
.option_items ⇒ Object
定义此命令使用的参数项(类方法,避免重复定义)
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 |
# File 'lib/pindo/command/ios/autobuild.rb', line 72 def self.option_items @option_items ||= begin items = Pindo::Options::OptionGroup.merge( Pindo::Options::BuildOptions.select(:bundleid, :build_type), Pindo::Options::JPSOptions.select(:proj, :upload, :send), Pindo::Options::UnityOptions.select(:skiplib, :skipyoo), Pindo::Options::UnityOptions.select_with_defaults(skipconfig: true), Pindo::Options::GitOptions.all ) # 为 bundleid 参数添加 value_block(交互式选择) bundleid_item = items.find { |item| item.key == :bundleid } if bundleid_item bundleid_item.value_block = proc do |command_instance| # 根据构建类型选择不同的 Bundle ID build_type = command_instance.instance_variable_get(:@build_type) || 'dev' Pindo::Options::BundleIdSelector.select_bundleid(build_type) end end items end end |
.options ⇒ Object
命令的选项列表
97 98 99 |
# File 'lib/pindo/command/ios/autobuild.rb', line 97 def self. option_items.map(&:to_claide_option).concat(super) end |
.use_cache? ⇒ Boolean
启用缓存机制
33 34 35 |
# File 'lib/pindo/command/ios/autobuild.rb', line 33 def self.use_cache? true # 此命令启用缓存 end |
Instance Method Details
#run ⇒ Object
134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 |
# File 'lib/pindo/command/ios/autobuild.rb', line 134 def run pindo_project_dir = Dir.pwd begin # 加载 JPS 配置(如果存在) Pindo::BuildHelper.share_instance.load_jps_build_config(pindo_project_dir) # 准备配置 config = prepare_ios_config(pindo_project_dir) # 创建并执行任务 tasks = make_build_task(config) # 添加到任务管理器并执行 task_manager = Pindo::TaskSystem::TaskManager.instance task_manager.clear_all tasks.each { |task| task_manager.add_task(task) } task_manager.start system "open #{pindo_project_dir}" ensure # 清除命令状态(如果启用了缓存,这里会自动保存) Pindo::Options::GlobalOptionsState.instance.clear end end |
#validate! ⇒ Object
129 130 131 132 |
# File 'lib/pindo/command/ios/autobuild.rb', line 129 def validate! super end |