Class: Fastlane::Actions::GitCommitAction

Inherits:
Fastlane::Action show all
Defined in:
fastlane/lib/fastlane/actions/git_commit.rb

Constant Summary

Constants inherited from Fastlane::Action

Fastlane::Action::AVAILABLE_CATEGORIES, Fastlane::Action::RETURN_TYPES

Documentation collapse

Class Method Summary collapse

Methods inherited from Fastlane::Action

action_name, author, deprecated_notes, details, lane_context, method_missing, other_action, return_type, sample_return_value, shell_out_should_use_bundle_exec?, step_text

Class Method Details

.authorsObject



58
59
60
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 58

def self.authors
  ["KrauseFx"]
end

.available_optionsObject



33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 33

def self.available_options
  [
    FastlaneCore::ConfigItem.new(key: :path,
                                 description: "The file you want to commit",
                                 is_string: false),
    FastlaneCore::ConfigItem.new(key: :message,
                                 description: "The commit message that should be used"),
    FastlaneCore::ConfigItem.new(key: :skip_git_hooks,
                                 description: "Set to true to pass --no-verify to git",
                                 type: Boolean,
                                 optional: true),
    FastlaneCore::ConfigItem.new(key: :allow_nothing_to_commit,
                                 description: "Set to true to allow commit without any git changes",
                                 type: Boolean,
                                 optional: true)
  ]
end

.categoryObject



75
76
77
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 75

def self.category
  :source_control
end

.descriptionObject



29
30
31
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 29

def self.description
  "Directly commit the given file with the given message"
end

.example_codeObject



66
67
68
69
70
71
72
73
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 66

def self.example_code
  [
    'git_commit(path: "./version.txt", message: "Version Bump")',
    'git_commit(path: ["./version.txt", "./changelog.txt"], message: "Version Bump")',
    'git_commit(path: ["./*.txt", "./*.md"], message: "Update documentation")',
    'git_commit(path: ["./*.txt", "./*.md"], message: "Update documentation", skip_git_hooks: true)'
  ]
end

.is_supported?(platform) ⇒ Boolean

Returns:



62
63
64
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 62

def self.is_supported?(platform)
  true
end

.outputObject



51
52
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 51

def self.output
end

.return_valueObject



54
55
56
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 54

def self.return_value
  nil
end

.run(params) ⇒ Object



4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# File 'fastlane/lib/fastlane/actions/git_commit.rb', line 4

def self.run(params)
  if params[:path].kind_of?(String)
    paths = params[:path].shellescape
  else
    paths = params[:path].map(&:shellescape).join(' ')
  end

  skip_git_hooks = params[:skip_git_hooks] ? '--no-verify' : ''

  if params[:allow_nothing_to_commit]
    repo_clean = Actions.sh("git status --porcelain").empty?
    UI.success("Nothing to commit, working tree clean ✅.") if repo_clean
    return if repo_clean
  end

  command = "git commit -m #{params[:message].shellescape} #{paths} #{skip_git_hooks}".strip
  result = Actions.sh(command)
  UI.success("Successfully committed \"#{params[:path]}\" 💾.")
  return result
end