ormdev 0.1.7 → 0.1.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +1 -1
- data/lib/ormdev/command/create.rb +8 -1
- data/lib/ormdev/source/core/create_helper.rb +31 -3
- data/lib/ormdev/source/util/download_util.rb +39 -0
- data/lib/ormdev/source/util/http_util.rb +1 -1
- data/lib/ormdev/version.rb +1 -1
- metadata +4 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 0d2bdbfdfcd5e054ba3331fabb1aec411d9c2b7eee6622473026cab8a975a0ad
|
4
|
+
data.tar.gz: 558371dd86d508d209426f1dab8e507b2cfaa42690d51cda8754fa2302092096
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: ed6668d63d1188e392bd2b0860622a155299cd3327be02b21e41d15b16d0ac36351d29395bde452adf2f85b2830dc8e4759f99d6f20ff5d433133380161a2e7d
|
7
|
+
data.tar.gz: 26da2af8226a9abe7d892eaa3188fe69178f1181115d1e3d1bfaedb70e15f294c8778e0ba17d33e5bbf09ab612ec4ec0469ff1a27b814fbbb8ca08632bb563e4
|
data/Gemfile.lock
CHANGED
@@ -7,6 +7,10 @@ module OrmDev
|
|
7
7
|
|
8
8
|
self.description = <<-DESC
|
9
9
|
新建 iOS => Application => Single View Application 工程,工程名为`NAME`
|
10
|
+
|
11
|
+
zip插件模板创建:
|
12
|
+
|
13
|
+
'ormdev create --template-url=http://112.65.142.83:7788/ceshi/tmpl/pod-fast-template.zip --fast CIPXxx'
|
10
14
|
DESC
|
11
15
|
|
12
16
|
self.arguments = [
|
@@ -15,7 +19,7 @@ module OrmDev
|
|
15
19
|
|
16
20
|
def self.options
|
17
21
|
[
|
18
|
-
['--template-url=URL', 'Orm插件模板git地址'],
|
22
|
+
['--template-url=URL', 'Orm插件模板git地址,或者zip地址'],
|
19
23
|
['--fast', '快速创建Orm插件模板工程(带测试用例)'],
|
20
24
|
['--prefix=XXX', 'Orm插件模板工程前缀(fast有效)'],
|
21
25
|
['--skip', '跳过打开Orm插件模板工程(fast有效)'],
|
@@ -37,6 +41,9 @@ module OrmDev
|
|
37
41
|
help! 'The Pod name cannot contain spaces.' if @name =~ /\s/
|
38
42
|
help! 'The Pod name cannot contain plusses.' if @name =~ /\+/
|
39
43
|
help! "The Pod name cannot begin with a '.'" if @name[0, 1] == '.'
|
44
|
+
unless @template_url then
|
45
|
+
help! '模板地址只能是以[git|zip]结尾的地址.' if !(@template_url.downcase.end_with?('.git') || @template_url.downcase.end_with?('.zip'))
|
46
|
+
end
|
40
47
|
end
|
41
48
|
|
42
49
|
def run
|
@@ -1,6 +1,8 @@
|
|
1
1
|
require 'cocoapods'
|
2
|
+
require 'zip'
|
2
3
|
|
3
4
|
require_relative '../util/sh_util'
|
5
|
+
require_relative '../util/download_util'
|
4
6
|
|
5
7
|
module OrmDev
|
6
8
|
class CreateHelper
|
@@ -54,8 +56,28 @@ module OrmDev
|
|
54
56
|
# @return [void]
|
55
57
|
#
|
56
58
|
def clone_template
|
57
|
-
|
58
|
-
|
59
|
+
if @template_url.downcase.end_with?('.zip') then
|
60
|
+
unzip_dir = File.basename(@template_url, 'zip')
|
61
|
+
abort('插件目录本地已存在。') if Dir.exist?(unzip_dir)
|
62
|
+
zip_path = File.join('./', File.basename(@template_url))
|
63
|
+
|
64
|
+
if (@template_url.downcase.start_with?('http://') || @template_url.downcase.start_with?('https://')) then
|
65
|
+
OrmDev::DownloadUtil.download( @template_url, zip_path )#Pathname.pwd
|
66
|
+
OrmDev::LogUtil.info "【创建插件工程】下载#{@template_url}到#{zip_path}"
|
67
|
+
elsif File.exist?(@template_url) then
|
68
|
+
OrmDev::LogUtil.info "【创建插件工程】复制#{@template_url}到#{zip_path}"
|
69
|
+
FileUtils.cp( @template_url, zip_path )
|
70
|
+
end
|
71
|
+
abort('插件模板zip下载失败') unless File.exist? zip_path
|
72
|
+
# 解压模板
|
73
|
+
result = OrmDev::SHUtil.run_command("unzip #{zip_path}",'解压模板工程', false)
|
74
|
+
File.rename('CIPPROJECT', @project_name)
|
75
|
+
FileUtils.rm zip_path
|
76
|
+
abort('插件模板zip解压失败') unless result
|
77
|
+
else
|
78
|
+
Pod::UI.section("Cloning `#{template_repo_url}` into `#{@project_name}`.") do
|
79
|
+
git! ['clone', template_repo_url, @project_name]
|
80
|
+
end
|
59
81
|
end
|
60
82
|
end
|
61
83
|
|
@@ -68,7 +90,8 @@ module OrmDev
|
|
68
90
|
# "PROJECT_OWNER" => @configurator.user_name,
|
69
91
|
"TODAYS_DATE" => Time.now.strftime("%m/%d/%Y"),
|
70
92
|
"TODAYS_YEAR" => Time.now.year.to_s,
|
71
|
-
"CIPPROJECT" => @project_name
|
93
|
+
"CIPPROJECT" => @project_name,
|
94
|
+
"cipPROJECT" => @project_name.gsub(/^CIP/, 'cip'),#模板替换,插件名->js对象
|
72
95
|
}
|
73
96
|
Dir.glob(project_folder + "/**/**/**/**").each do |name|
|
74
97
|
next if Dir.exists? name
|
@@ -103,6 +126,9 @@ module OrmDev
|
|
103
126
|
safe_rename_file("#{project_folder}/Example/CIPPROJECT.xcworkspace", "#{project_folder}/Example/#{@project_name}.xcworkspace")
|
104
127
|
safe_rename_file("#{project_folder}/Example/CIPPROJECT/CIPPROJECT-Info.plist", "#{project_folder}/Example/CIPPROJECT/#{@project_name}-Info.plist")
|
105
128
|
safe_rename_file("#{project_folder}/Example/CIPPROJECT/CIPPROJECT-Prefix.pch", "#{project_folder}/Example/CIPPROJECT/#{@project_name}-Prefix.pch")
|
129
|
+
#模板替换
|
130
|
+
safe_rename_file("#{project_folder}/Example/CIPPROJECT/asset/www/V2/data/CIPPROJECT.js", "#{project_folder}/Example/CIPPROJECT/asset/www/V2/data/#{@project_name}.js")
|
131
|
+
safe_rename_file("#{project_folder}/Example/CIPPROJECT/asset/www/V2/html/CIPPROJECT.html", "#{project_folder}/Example/CIPPROJECT/asset/www/V2/html/#{@project_name}.html")
|
106
132
|
safe_rename_file("#{project_folder}/Example/CIPPROJECT", "#{project_folder}/Example/#{@project_name}")
|
107
133
|
safe_rename_file("#{project_folder}/CIPPROJECT/Classes/CIPPROJECT.h", "#{project_folder}/CIPPROJECT/Classes/#{@project_name}.h")
|
108
134
|
safe_rename_file("#{project_folder}/CIPPROJECT/Classes/CIPPROJECT.m", "#{project_folder}/CIPPROJECT/Classes/#{@project_name}.m")
|
@@ -112,6 +138,7 @@ module OrmDev
|
|
112
138
|
safe_rename_file("#{project_folder}/CIPPROJECT/Classes/CIPPROJECTMacros.h", "#{project_folder}/CIPPROJECT/Classes/#{@project_name}Macros.h")
|
113
139
|
safe_rename_file("#{project_folder}/CIPPROJECT", "#{project_folder}/#{@project_name}")
|
114
140
|
safe_rename_file("#{project_folder}/CIPPROJECT.podspec", "#{project_folder}/#{@project_name}.podspec")
|
141
|
+
|
115
142
|
reinitialize_svn_repo
|
116
143
|
|
117
144
|
OrmDev::LogUtil.info "\nRunning " + "pod install".magenta + " on your new library."
|
@@ -135,6 +162,7 @@ module OrmDev
|
|
135
162
|
|
136
163
|
def reinitialize_svn_repo
|
137
164
|
`rm -rf .svn`
|
165
|
+
`rm -rf .git`
|
138
166
|
end
|
139
167
|
|
140
168
|
def safe_rename_dir(old, dir_name)
|
@@ -0,0 +1,39 @@
|
|
1
|
+
require 'net/http'
|
2
|
+
require 'uri'
|
3
|
+
require 'ruby-progressbar'
|
4
|
+
|
5
|
+
module OrmDev
|
6
|
+
class DownloadUtil
|
7
|
+
def self.download(url, save_path, title = '文件')
|
8
|
+
uri = URI(url)
|
9
|
+
Net::HTTP.start(uri.host, uri.port) do |http|
|
10
|
+
request = Net::HTTP::Get.new uri
|
11
|
+
http.request request do |response|
|
12
|
+
file_size = response['content-length'].to_i
|
13
|
+
pbar = ProgressBar.create(:title => title, :starting_at => 0, :total => file_size, :format => '%a |%b>>%i| %p%% %t')
|
14
|
+
amount_downloaded = 0
|
15
|
+
File.open save_path, 'wb' do |io| # 'b' opens the file in binary mode
|
16
|
+
response.read_body do |chunk|
|
17
|
+
io.write chunk
|
18
|
+
amount_downloaded += chunk.size
|
19
|
+
pbar.progress=amount_downloaded
|
20
|
+
# puts "%.2f%" % (amount_downloaded.to_f / file_size * 100)
|
21
|
+
end
|
22
|
+
end
|
23
|
+
pbar.finish
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.download_cp(path, save_dir, save_name, title = '文件')
|
29
|
+
save_path = File.join(save_dir, save_name)
|
30
|
+
FileUtils.mkdir_p(save_dir) unless Dir.exist?(save_dir)
|
31
|
+
FileUtils.rm_rf(save_path) if Dir.exist?(save_path)
|
32
|
+
if (path.downcase.start_with?('http://') || path.downcase.start_with?('https://')) then
|
33
|
+
ORM::DownloadUtil.download(path, save_path, title )
|
34
|
+
else
|
35
|
+
FileUtils.cp( path, save_path )
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
data/lib/ormdev/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ormdev
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.8
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- devorm
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2018-12-
|
11
|
+
date: 2018-12-11 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: claide
|
@@ -205,6 +205,7 @@ files:
|
|
205
205
|
- lib/ormdev/command/update.rb
|
206
206
|
- lib/ormdev/source/core/create_helper.rb
|
207
207
|
- lib/ormdev/source/core/run_helper.rb
|
208
|
+
- lib/ormdev/source/util/download_util.rb
|
208
209
|
- lib/ormdev/source/util/http_util.rb
|
209
210
|
- lib/ormdev/source/util/log_util.rb
|
210
211
|
- lib/ormdev/source/util/sh_util.rb
|
@@ -219,7 +220,7 @@ post_install_message: "\e[32m\n _____ __ __ ________\n
|
|
219
220
|
___ \\ / / / / / _ _ /\n / / / // /_/ / / // // /\n / / / //
|
220
221
|
____/ / // // /\n / /__/ // / / // // /\n \\_____//_/ /_//_//_/
|
221
222
|
\ Dev\n\n\n -- 欢迎使用OrmDev for iOS --\n ---- 技术支持:devorm@163.com ----\n\n
|
222
|
-
\ \e[0m\t\t\t\tv0.1.
|
223
|
+
\ \e[0m\t\t\t\tv0.1.8\n\n"
|
223
224
|
rdoc_options: []
|
224
225
|
require_paths:
|
225
226
|
- lib
|