Sha256: 9b1577124b9f8ea07b5d2544f1de37a6e9cc020c3086b2730b80a75ebe65b504

Contents?: true

Size: 1.32 KB

Versions: 1

Compression:

Stored size: 1.32 KB

Contents

# encoding: UTF-8

module Rosette
  module Queuing
    module Commits

      # Extracts phrases from the given commit and stores them in the datastore.
      #
      # @see RepoConfig
      class ExtractStage < Stage
        accepts PhraseStatus::FETCHED

        # Executes this stage and updates the commit log with an +EXTRACTED+
        # status. Uses [Rosette::Core::Commands::CommitCommand] under the hood.
        # If the commit no longer exists in the git repository, the commit log
        # will be updated with a status of +MISSING+.
        #
        # @return [void]
        def execute!
          logger.info("Extracting phrases for #{commit_log.commit_id}")

          Rosette::Core::Commands::CommitCommand.new(rosette_config)
            .set_repo_name(repo_config.name)
            .set_ref(commit_log.commit_id)
            .execute

          commit_log.extract
          commit_log.commit_datetime = Time.at(rev_commit.getCommitTime)

          logger.info("Finished extracting phrases for #{commit_log.commit_id}")
        rescue Java::OrgEclipseJgitErrors::MissingObjectException => e
          commit_log.missing
        ensure
          save_commit_log
        end

        protected

        def rev_commit
          @rev_commit ||= repo_config.repo.get_rev_commit(commit_log.commit_id)
        end
      end

    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
rosette-core-1.0.1 lib/rosette/queuing/commits/extract_stage.rb