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.
116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 |
# File 'lib/pindo/command/ios/autobuild.rb', line 116 def initialize(argv) @options = (argv) # 保存参数到实例变量 @args_conf = @options[:conf] @args_bundle_id = @options[:bundleid] @build_type = @options[:build_type] || 'dev' # 标准化构建类型(dev -> development, release -> appstore) @build_type = Pindo::Options::BuildOptions.normalize_build_type(@build_type) # send、media 或 bind 都依赖 upload:如果指定了任一参数,自动启用 upload @args_upload_flag = @options[:send] || @options[:bind] || @options[:media] || @options[:upload] # media 任务是独立的,不依赖任何其他任务,但是为输入命令参数更加简单,如果有--bind和--send, 则默认认为一定会有--media参数 @args_media_flag = @options[:send] || @options[:bind] || @options[:media] || false # send 都依赖 bind:如果指定了任一参数,自动启用 bind @args_bind_flag = @options[:send] ||@options[:bind] || false @args_send_flag = @options[:send] # Unity 参数 @args_skip_lib = @options[:skiplib] || false @args_skip_yoo = @options[:skipyoo] || false # Task 参数 @args_multi_flag = @options[:multi] || false # Git 参数 @args_release_branch = @options[:release_branch] || 'master' @args_ver_inc = Pindo::Options::GitOptions.parse_version_increase_type(@options[:ver_inc]) @args_tag_type = Pindo::Options::GitOptions.parse_create_tag_type(@options[:tag_type]) @args_tag_pre = @options[:tag_pre] || 'v' @args_git_commit = Pindo::Options::GitOptions.parse_git_commit_type(@options[:git_commit]) super @additional_args = argv.remainder! end |
Class Method Details
.option_items ⇒ Object
定义此命令使用的参数项(类方法,避免重复定义)
100 101 102 103 104 105 106 107 108 109 |
# File 'lib/pindo/command/ios/autobuild.rb', line 100 def self.option_items @option_items ||= Pindo::Options::OptionGroup.merge( Pindo::Options::BuildOptions.select(:bundleid, :build_type), Pindo::Options::JPSOptions.select(:conf, :upload, :media, :bind, :send), Pindo::Options::UnityOptions.select(:skiplib, :skipyoo), Pindo::Options::UnityOptions.select_with_defaults(skipmacro: true), Pindo::Options::TaskOptions.select(:multi), Pindo::Options::GitOptions.all ) end |
.options ⇒ Object
命令的选项列表
112 113 114 |
# File 'lib/pindo/command/ios/autobuild.rb', line 112 def self. option_items.map(&:to_claide_option).concat(super) end |
.use_cache? ⇒ Boolean
启用缓存机制
35 36 37 |
# File 'lib/pindo/command/ios/autobuild.rb', line 35 def self.use_cache? true # 此命令启用缓存 end |
Instance Method Details
#run ⇒ Object
164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 |
# File 'lib/pindo/command/ios/autobuild.rb', line 164 def run pindo_project_dir = Dir.pwd begin # 加载 JPS 配置(缓存 project_name,并通过映射表解析 bundle_id) Pindo::BuildHelper.share_instance.load_jps_build_config(pindo_project_dir, conf: @args_conf) # 解析 bundle_id(优先级:命令行参数 > JPSBuildConfig映射 > 交互选择) resolve_bundle_id! # 准备配置 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) } # 执行任务(根据 --multi 参数决定模式) if @args_multi_flag task_manager.start(mode: :concurrent, max_workers: 3) else task_manager.start end system "open #{pindo_project_dir}" ensure # 清除命令状态(如果启用了缓存,这里会自动保存) Pindo::Options::GlobalOptionsState.instance.clear end end |
#validate! ⇒ Object
159 160 161 162 |
# File 'lib/pindo/command/ios/autobuild.rb', line 159 def validate! super # 基类的 HelpValidator 会统一处理 --help # bundle_id 校验推迟到 run 中,在 load_jps_build_config 之后解析 end |