fastlane-plugin-static_assets 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: b8cc591df3ad12f9c0cec748628e4e0ad11c19de
4
+ data.tar.gz: 42746a59b7af3f80957c9f4c09d90c243f8c7def
5
+ SHA512:
6
+ metadata.gz: 847f4419242b0bd51a3b18ca709bbfc165cc24c156b27f1cc90f2976c1722759af51e792199bbffbdbd75f2d7f0528ee25d45c5ce6196e79b37e4c949345695e
7
+ data.tar.gz: afe7dc3028c5e8e354ef2fe1d2122f8d6c6488e724155dff0518671aab357318e837917adb39a1e2b3e2dc1f7e7ecec936a0a30af2639bad50712c83dd74b90b
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2017 Jakob Jensen <jje@trifork.com>
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,52 @@
1
+ # static_assets plugin
2
+
3
+ [![fastlane Plugin Badge](https://rawcdn.githack.com/fastlane/fastlane/master/fastlane/assets/plugin-badge.svg)](https://rubygems.org/gems/fastlane-plugin-static_assets)
4
+
5
+ ## Getting Started
6
+
7
+ This project is a [fastlane](https://github.com/fastlane/fastlane) plugin. To get started with `fastlane-plugin-static_assets`, add it to your project by running:
8
+
9
+ ```bash
10
+ fastlane add_plugin static_assets
11
+ ```
12
+
13
+ ## About static_assets
14
+
15
+ Generate code for buildtime-safe assignments of assets.
16
+
17
+ **Note to author:** Add a more detailed description about this plugin here. If your plugin contains multiple actions, make sure to mention them here.
18
+
19
+ ## Example
20
+
21
+ Check out the [example `Fastfile`](fastlane/Fastfile) to see how to use this plugin. Try it by cloning the repo, running `fastlane install_plugins` and `bundle exec fastlane test`.
22
+
23
+ **Note to author:** Please set up a sample project to make it easy for users to explore what your plugin does. Provide everything that is necessary to try out the plugin in this project (including a sample Xcode/Android project if necessary)
24
+
25
+ ## Run tests for this plugin
26
+
27
+ To run both the tests, and code style validation, run
28
+
29
+ ```
30
+ rake
31
+ ```
32
+
33
+ To automatically fix many of the styling issues, use
34
+ ```
35
+ rubocop -a
36
+ ```
37
+
38
+ ## Issues and Feedback
39
+
40
+ For any other issues and feedback about this plugin, please submit it to this repository.
41
+
42
+ ## Troubleshooting
43
+
44
+ If you have trouble using plugins, check out the [Plugins Troubleshooting](https://docs.fastlane.tools/plugins/plugins-troubleshooting/) guide.
45
+
46
+ ## Using `fastlane` Plugins
47
+
48
+ For more information about how the `fastlane` plugin system works, check out the [Plugins documentation](https://docs.fastlane.tools/plugins/create-plugin/).
49
+
50
+ ## About `fastlane`
51
+
52
+ `fastlane` is the easiest way to automate beta deployments and releases for your iOS and Android apps. To learn more, check out [fastlane.tools](https://fastlane.tools).
@@ -0,0 +1,16 @@
1
+ require 'fastlane/plugin/static_assets/version'
2
+
3
+ module Fastlane
4
+ module StaticAssets
5
+ # Return all .rb files inside the "actions" and "helper" directory
6
+ def self.all_classes
7
+ Dir[File.expand_path('**/{actions,helper}/*.rb', File.dirname(__FILE__))]
8
+ end
9
+ end
10
+ end
11
+
12
+ # By default we want to import all available actions and helpers
13
+ # A plugin can contain any number of actions and plugins
14
+ Fastlane::StaticAssets.all_classes.each do |current|
15
+ require current
16
+ end
@@ -0,0 +1,84 @@
1
+ module Fastlane
2
+ module Actions
3
+ class StaticImagesAction < Action
4
+ def self.run(params)
5
+ unless params[:paths].kind_of?(Array)
6
+ params[:paths] = [params[:paths]]
7
+ end
8
+
9
+ image_names = []
10
+ params[:paths].each do |path|
11
+ path_arr = Dir["#{FastlaneCore::FastlaneFolder.path}../#{path}/**/*.imageset"].each do |image_path|
12
+ path_arr = image_path.split('/')
13
+ image_name = path_arr[path_arr.length - 1].sub('.imageset', '')
14
+ if image_names.include?(image_name)
15
+ raise "'#{image_name}' is a duplicate".red
16
+ end
17
+ image_names << image_name
18
+ end
19
+ end
20
+ output_path = "#{FastlaneCore::FastlaneFolder.path}/../#{params[:output]}"
21
+ FileUtils.mkdir_p(File.dirname(output_path))
22
+ file = open(output_path, 'w')
23
+
24
+ if params[:is_xamarin]
25
+ file.write("using System;\nusing UIKit;\npublic class Images {\n")
26
+ image_names.each do |image_name|
27
+ sanitized_image_name = sanitize_name(image_name)
28
+ file.write("\tpublic static UIImage #{sanitized_image_name} { get { return UIImage.FromBundle(\"#{image_name}\"); } }\n")
29
+ end
30
+ file.write("}")
31
+ else
32
+ file.write("import UIKit\nstruct Images {\n")
33
+
34
+ image_names.each do |image_name|
35
+ sanitized_image_name = sanitize_name(image_name)
36
+ file.write("\tstatic let #{sanitized_image_name} = UIImage(named:\"#{image_name}\")!\n")
37
+ end
38
+ file.write("}")
39
+ end
40
+
41
+ file.close
42
+ end
43
+
44
+ def self.sanitize_name(name)
45
+ name.tr(' ', '_')
46
+ end
47
+
48
+ def self.description
49
+ "Generate code for buildtime-safe assignments of images."
50
+ end
51
+
52
+ def self.authors
53
+ ["Krzysztof Piatkowski", "Jakob Jensen"]
54
+ end
55
+
56
+ def self.return_value
57
+ end
58
+
59
+ def self.details
60
+ end
61
+
62
+ def self.available_options
63
+ [
64
+ FastlaneCore::ConfigItem.new(key: :output,
65
+ env_name: "FL_IOS_IMAGE_ASSET_OUTPUT",
66
+ description: "output file"),
67
+ FastlaneCore::ConfigItem.new(key: :paths,
68
+ env_name: "FL_IOS_IMAGE_ASSET_PATHS",
69
+ description: "single path or Array of paths to image assets to convert",
70
+ is_string: false),
71
+ FastlaneCore::ConfigItem.new(key: :is_xamarin,
72
+ env_name: "FL_IOS_IMAGE_ASSET_IS_XAMARIN",
73
+ description: "should output as xamarin (C#)?",
74
+ default_value: false,
75
+ is_string: false)
76
+ ]
77
+ end
78
+
79
+ def self.is_supported?(platform)
80
+ [:ios].include? platform
81
+ end
82
+ end
83
+ end
84
+ end
@@ -0,0 +1,12 @@
1
+ module Fastlane
2
+ module Helper
3
+ class StaticAssetsHelper
4
+ # class methods that you define here become available in your action
5
+ # as `Helper::StaticAssetsHelper.your_method`
6
+ #
7
+ def self.show_message
8
+ UI.message("Hello from the static_assets plugin helper!")
9
+ end
10
+ end
11
+ end
12
+ end
@@ -0,0 +1,5 @@
1
+ module Fastlane
2
+ module StaticAssets
3
+ VERSION = "1.0.0"
4
+ end
5
+ end
metadata ADDED
@@ -0,0 +1,133 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: fastlane-plugin-static_assets
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Jakob Jensen
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2017-01-20 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: pry
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - '>='
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - '>='
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: bundler
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - '>='
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - '>='
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rspec
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - '>='
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - '>='
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rake
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - '>='
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - '>='
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rubocop
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - '>='
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - '>='
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: fastlane
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - '>='
88
+ - !ruby/object:Gem::Version
89
+ version: 2.9.0
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - '>='
95
+ - !ruby/object:Gem::Version
96
+ version: 2.9.0
97
+ description:
98
+ email: jje@trifork.com
99
+ executables: []
100
+ extensions: []
101
+ extra_rdoc_files: []
102
+ files:
103
+ - lib/fastlane/plugin/static_assets/actions/static_images_action.rb
104
+ - lib/fastlane/plugin/static_assets/helper/static_assets_helper.rb
105
+ - lib/fastlane/plugin/static_assets/version.rb
106
+ - lib/fastlane/plugin/static_assets.rb
107
+ - README.md
108
+ - LICENSE
109
+ homepage:
110
+ licenses:
111
+ - MIT
112
+ metadata: {}
113
+ post_install_message:
114
+ rdoc_options: []
115
+ require_paths:
116
+ - lib
117
+ required_ruby_version: !ruby/object:Gem::Requirement
118
+ requirements:
119
+ - - '>='
120
+ - !ruby/object:Gem::Version
121
+ version: '0'
122
+ required_rubygems_version: !ruby/object:Gem::Requirement
123
+ requirements:
124
+ - - '>='
125
+ - !ruby/object:Gem::Version
126
+ version: '0'
127
+ requirements: []
128
+ rubyforge_project:
129
+ rubygems_version: 2.0.14.1
130
+ signing_key:
131
+ specification_version: 4
132
+ summary: Generate code for buildtime-safe assignments of assets.
133
+ test_files: []