Refactor version.rb and add output to PRs. — tk (#12388)

* Refactor version.rb and add output to PRs.

Signed-off-by: Satadru Pramanik <satadru@gmail.com>

* Update tk homepage.

Signed-off-by: Satadru Pramanik <satadru@gmail.com>

* Adjust PR creation text logic.

Signed-off-by: Satadru Pramanik <satadru@gmail.com>

---------

Signed-off-by: Satadru Pramanik <satadru@gmail.com>
This commit is contained in:
Satadru Pramanik, DO, MPH, MEng
2025-08-08 15:15:50 -04:00
committed by GitHub
parent 404b6817ef
commit ef26c23a47
5 changed files with 185 additions and 91 deletions

View File

@@ -322,6 +322,17 @@ jobs:
fetch-depth: 0 fetch-depth: 0
persist-credentials: true persist-credentials: true
ref: ${{ inputs.branch || github.ref_name }} ref: ${{ inputs.branch || github.ref_name }}
- name: Install ruby-libversion # Hopefully this will get added as an Ubuntu/Debian package. https://github.com/repology/libversion/issues/35
working-directory: ${{ runner.temp }}
run: |
git clone --depth 1 -b 3.0.3 https://github.com/repology/libversion
cd libversion
mkdir build
cd build
cmake ..
make -j "$(nproc)"
sudo make install
sudo gem install ruby-libversion
- name: Rebase to master and save git log - name: Rebase to master and save git log
id: rebase-and-git-log id: rebase-and-git-log
run: | run: |
@@ -375,6 +386,7 @@ jobs:
x86_64_PACKAGES: ${{ needs.setup.outputs.x86_64_packages }} x86_64_PACKAGES: ${{ needs.setup.outputs.x86_64_packages }}
armv7l_PACKAGES: ${{ needs.setup.outputs.armv7l_packages }} armv7l_PACKAGES: ${{ needs.setup.outputs.armv7l_packages }}
run: | run: |
function join_by { local IFS="$1"; shift; echo "$*"; }
rm -rf /tmp/pr.txt rm -rf /tmp/pr.txt
echo -e "## Description" >> /tmp/pr.txt echo -e "## Description" >> /tmp/pr.txt
echo -e "#### Commits:" >> /tmp/pr.txt echo -e "#### Commits:" >> /tmp/pr.txt
@@ -391,7 +403,21 @@ jobs:
echo -e "### Packages with Updated versions or Changed package files:" >> /tmp/pr.txt echo -e "### Packages with Updated versions or Changed package files:" >> /tmp/pr.txt
for file in ${CHANGED_PACKAGES} for file in ${CHANGED_PACKAGES}
do do
echo "- ${file}" >> /tmp/pr.txt pkg_version="$(./tools/version.rb -j "${file}" | jq -r '.[]|.version')"
upstream_version="$(tools/version.rb tcl -j | jq -r '.[]|.upstream_version')"
if [[ -z "$pkg_version" ]]; then
echo "- ${file}" >> /tmp/pr.txt
PKG_DELTA+=( "${file}" )
elif [[ -z "$upstream_version" ]]; then
echo "- ${file} => ${pkg_version}" >> /tmp/pr.txt
PKG_DELTA+=( "${file} => ${pkg_version}" )
elif [[ "$pkg_version" == "$upstream_version" ]]; then
echo "- ${file} => ${pkg_version}" >> /tmp/pr.txt
PKG_DELTA+=( "${file} => ${pkg_version}" )
else
echo "- ${file} => ${pkg_version} (current version is ${upstream_version})" >> /tmp/pr.txt
PKG_DELTA+=( "${file} => ${pkg_version}" )
fi
done done
echo -e "##\nBuilds attempted for:" >> /tmp/pr.txt echo -e "##\nBuilds attempted for:" >> /tmp/pr.txt
[ -n "${x86_64_PACKAGES}" ] && echo -e "- [x] \`x86_64\`" >> /tmp/pr.txt [ -n "${x86_64_PACKAGES}" ] && echo -e "- [x] \`x86_64\`" >> /tmp/pr.txt
@@ -411,14 +437,16 @@ jobs:
echo -e "##\n### Run the following to get this pull request's changes locally for testing.\n\`\`\`bash" >> /tmp/pr.txt echo -e "##\n### Run the following to get this pull request's changes locally for testing.\n\`\`\`bash" >> /tmp/pr.txt
echo -e "CREW_REPO=https://github.com/chromebrew/chromebrew.git CREW_BRANCH=${{ inputs.branch || github.ref_name }} crew update \\" >> /tmp/pr.txt echo -e "CREW_REPO=https://github.com/chromebrew/chromebrew.git CREW_BRANCH=${{ inputs.branch || github.ref_name }} crew update \\" >> /tmp/pr.txt
echo -e "&& yes | crew upgrade\n\`\`\`" >> /tmp/pr.txt echo -e "&& yes | crew upgrade\n\`\`\`" >> /tmp/pr.txt
[[ -n "${PKG_DELTA[*]}" ]] && PKG_DELTAS="— $(join_by , "${PKG_DELTA[@]}")"
echo "PKG_DELTAS: $PKG_DELTAS"
cat /tmp/pr.txt cat /tmp/pr.txt
[[ $DRAFT_PR == 'true' ]] && export PR_DRAFT_FLAG='-d' [[ $DRAFT_PR == 'true' ]] && export PR_DRAFT_FLAG='-d'
PR_NUMBER=$(gh pr list -L 1 -s open -H ${{ inputs.branch || github.ref_name }} | cut -f1) PR_NUMBER=$(gh pr list -L 1 -s open -H ${{ inputs.branch || github.ref_name }} | cut -f1)
echo "PR title is: $(echo "${{ inputs.pr_title || inputs.branch || github.ref_name }}" | sed -e "s/^'//" -e "s/'$//") — ${CHANGED_PACKAGES}" echo "PR title is: $(echo "${{ inputs.pr_title || inputs.branch || github.ref_name }}" | sed -e "s/^'//" -e "s/'$//") ${PKG_DELTAS}"
if [[ -z ${PR_NUMBER} ]]; then if [[ -z ${PR_NUMBER} ]]; then
PR_NUMBER=$(gh pr create ${PR_DRAFT_FLAG} --reviewer chromebrew/active --title "$(echo "${{ inputs.pr_title || inputs.branch || github.ref_name }}" | sed -e "s/^'//" -e "s/'$//") — ${CHANGED_PACKAGES}" -F /tmp/pr.txt | rev | cut -d"/" -f1 | rev) PR_NUMBER=$(gh pr create ${PR_DRAFT_FLAG} --reviewer chromebrew/active --title "$(echo "${{ inputs.pr_title || inputs.branch || github.ref_name }}" | sed -e "s/^'//" -e "s/'$//") ${PKG_DELTAS}" -F /tmp/pr.txt | rev | cut -d"/" -f1 | rev)
else else
gh pr edit --add-reviewer chromebrew/active --title "$(echo "${{ inputs.pr_title || inputs.branch || github.ref_name }}" | sed -e "s/^'//" -e "s/'$//") — ${CHANGED_PACKAGES}" -F /tmp/pr.txt gh pr edit --add-reviewer chromebrew/active --title "$(echo "${{ inputs.pr_title || inputs.branch || github.ref_name }}" | sed -e "s/^'//" -e "s/'$//") ${PKG_DELTAS}" -F /tmp/pr.txt
fi fi
# Draft PRs can not be set to automerge. # Draft PRs can not be set to automerge.
if [[ $DRAFT_PR == 'true' ]]; then if [[ $DRAFT_PR == 'true' ]]; then

View File

@@ -24,7 +24,7 @@ jobs:
ruby-version: '3.4.5' ruby-version: '3.4.5'
- name: Install Python pip - name: Install Python pip
run: sudo apt install -y python3-pip run: sudo apt install -y python3-pip
- name: Install ruby-libversion # Hopefully this will get added as an Ubuntu/Debian package so we don't have to do this manually. - name: Install ruby-libversion # Hopefully this will get added as an Ubuntu/Debian package. https://github.com/repology/libversion/issues/35
working-directory: ${{ runner.temp }} working-directory: ${{ runner.temp }}
run: | run: |
git clone --depth 1 -b 3.0.3 https://github.com/repology/libversion git clone --depth 1 -b 3.0.3 https://github.com/repology/libversion
@@ -47,17 +47,22 @@ jobs:
git pull git pull
git stash drop || true git stash drop || true
LD_LIBRARY_PATH=/usr/local/lib ruby tools/update_python_pip_packages.rb LD_LIBRARY_PATH=/usr/local/lib ruby tools/update_python_pip_packages.rb
export TIMESTAMP="$(date -u +%F-%H-%M)"
for i in $(git status --porcelain | awk '{print $2}' | grep ^packages/) for i in $(git status --porcelain | awk '{print $2}' | grep ^packages/)
do do
git stash pop || true git stash pop || true
git add $i git add $i
pkg=${i%.rb} pkg=${i%.rb}
pkg=${pkg#packages/} pkg=${pkg#packages/}
git checkout -b "${pkg}-${TIMESTAMP}" || git checkout "${pkg}-${TIMESTAMP}" pkg_version="$(./tools/version.rb -j ${pkg} | jq -r '.[]|.version')"
git commit -m "Add unbuilt ${pkg} to ${pkg}-${TIMESTAMP}" if [[ -z "$pkg_version" ]]; then
branch_tag="$(date -u +%F-%H-%M)"
else
branch_tag="${pkg_version}"
fi
git checkout -b "${pkg}-${branch_tag}" || git checkout "${pkg}-${branch_tag}"
git commit -m "Add unbuilt ${pkg} to ${pkg}-${branch_tag}"
git push git push
gh workflow -R chromebrew/chromebrew run Build.yml -f branch="${pkg}-${TIMESTAMP}" gh workflow -R chromebrew/chromebrew run Build.yml -f branch="${pkg}-${branch_tag}"
git stash || true git stash || true
git checkout master git checkout master
done done
@@ -67,17 +72,22 @@ jobs:
git pull git pull
git stash drop || true git stash drop || true
LD_LIBRARY_PATH=/usr/local/lib ruby tools/update_ruby_gem_packages.rb LD_LIBRARY_PATH=/usr/local/lib ruby tools/update_ruby_gem_packages.rb
export TIMESTAMP="$(date -u +%F-%H-%M)"
for i in $(git status --porcelain | awk '{print $2}' | grep ^packages/) for i in $(git status --porcelain | awk '{print $2}' | grep ^packages/)
do do
git stash pop || true git stash pop || true
git add $i git add $i
pkg=${i%.rb} pkg=${i%.rb}
pkg=${pkg#packages/} pkg=${pkg#packages/}
git checkout -b "${pkg}-${TIMESTAMP}" || git checkout "${pkg}-${TIMESTAMP}" pkg_version="$(./tools/version.rb -j ${pkg} | jq -r '.[]|.version')"
git commit -m "Add unbuilt ${pkg} to ${pkg}-${TIMESTAMP}" if [[ -z "$pkg_version" ]]; then
branch_tag="$(date -u +%F-%H-%M)"
else
branch_tag="${pkg_version}"
fi
git checkout -b "${pkg}-${branch_tag}" || git checkout "${pkg}-${branch_tag}"
git commit -m "Add unbuilt ${pkg} to ${pkg}-${branch_tag}"
git push git push
gh workflow -R chromebrew/chromebrew run Build.yml -f branch="${pkg}-${TIMESTAMP}" gh workflow -R chromebrew/chromebrew run Build.yml -f branch="${pkg}-${branch_tag}"
git stash || true git stash || true
git checkout master git checkout master
done done

View File

@@ -4,7 +4,7 @@ require 'etc'
require 'open3' require 'open3'
OLD_CREW_VERSION ||= defined?(CREW_VERSION) ? CREW_VERSION : '1.0' OLD_CREW_VERSION ||= defined?(CREW_VERSION) ? CREW_VERSION : '1.0'
CREW_VERSION ||= '1.64.0' unless defined?(CREW_VERSION) && CREW_VERSION == OLD_CREW_VERSION CREW_VERSION ||= '1.64.1' unless defined?(CREW_VERSION) && CREW_VERSION == OLD_CREW_VERSION
# Kernel architecture. # Kernel architecture.
KERN_ARCH ||= Etc.uname[:machine] KERN_ARCH ||= Etc.uname[:machine]
@@ -175,6 +175,22 @@ unless defined?(CHROMEOS_RELEASE)
end end
end end
# Some packges need manual adjustments of URLS for different versions.
excluded_pkgs = Set[
{ pkg_name: 'py3_atspi', comments: 'Does not work with pip.' },
{ pkg_name: 'cf', comments: 'Uses a dynamic source package URL.' },
{ pkg_name: 'cursor', comments: 'Uses a dynamic source package URL.' },
{ pkg_name: 'py3_ldapdomaindump', comments: 'Build is broken.' }
].map { |h| h[:pkg_name] }
CREW_AUTOMATIC_VERSION_UPDATE_EXCLUSION_REGEX = "(#{excluded_pkgs.join('|')})" unless defined?(CREW_AUTOMATIC_VERSION_UPDATE_EXCLUSION_REGEX)
# Some packages have different names in anitya.
unless defined?(CREW_ANITYA_PACKAGE_NAME_MAPPINGS)
CREW_ANITYA_PACKAGE_NAME_MAPPINGS = Set[
{ pkg_name: 'cvs', anitya_pkg: 'cvs-stable', comments: '' }
].to_h { |h| [h[:pkg_name], h[:anitya_pkg]] }
end
# If CREW_DISABLE_MVDIR environment variable exists and is equal to 1 use rsync/tar to install files in lieu of crew-mvdir. # If CREW_DISABLE_MVDIR environment variable exists and is equal to 1 use rsync/tar to install files in lieu of crew-mvdir.
CREW_DISABLE_MVDIR ||= ENV.fetch('CREW_DISABLE_MVDIR', false) unless defined?(CREW_DISABLE_MVDIR) CREW_DISABLE_MVDIR ||= ENV.fetch('CREW_DISABLE_MVDIR', false) unless defined?(CREW_DISABLE_MVDIR)

View File

@@ -2,7 +2,7 @@ require 'buildsystems/autotools'
class Tk < Autotools class Tk < Autotools
description 'Tk is a graphical user interface toolkit that takes developing desktop applications to a higher level than conventional approaches.' description 'Tk is a graphical user interface toolkit that takes developing desktop applications to a higher level than conventional approaches.'
homepage 'http://www.tcl.tk/' homepage 'https://tcl.tk'
version '9.0.1' version '9.0.1'
license 'tcltk' license 'tcltk'
compatibility 'aarch64 armv7l x86_64' compatibility 'aarch64 armv7l x86_64'

View File

@@ -1,7 +1,7 @@
#!/usr/bin/env ruby #!/usr/bin/env ruby
# version.rb version 1.3 (for Chromebrew) # version.rb version 1.4 (for Chromebrew)
OPTIONS = %w[-h --help -u --update-package-files -v --verbose] OPTIONS = %w[-h --help -j --json -u --update-package-files -v --verbose]
if ARGV.include?('-h') || ARGV.include?('--help') if ARGV.include?('-h') || ARGV.include?('--help')
abort <<~EOM abort <<~EOM
@@ -11,6 +11,7 @@ if ARGV.include?('-h') || ARGV.include?('--help')
If <package> is omitted, all packages will be processed. If <package> is omitted, all packages will be processed.
Passing --update-package-files or -u will try to update the version Passing --update-package-files or -u will try to update the version
field in the package file. field in the package file.
Passing --json or -j will only give json output.
EOM EOM
end end
@@ -20,30 +21,25 @@ require 'net/http'
require 'ruby_libversion' require 'ruby_libversion'
require 'uri/http' require 'uri/http'
crew_local_repo_root = `git rev-parse --show-toplevel 2> /dev/null`.chomp
# When invoked from crew, pwd is CREW_DEST_DIR, so crew_local_repo_root
# is empty.
crew_local_repo_root = '../' if crew_local_repo_root.to_s.empty?
require File.join(crew_local_repo_root, 'lib/color')
require File.join(crew_local_repo_root, 'lib/const')
require File.join(crew_local_repo_root, 'lib/package')
require File.join(crew_local_repo_root, 'lib/package_utils')
# Add >LOCAL< lib to LOAD_PATH # Add >LOCAL< lib to LOAD_PATH
$LOAD_PATH.unshift '../lib' $LOAD_PATH.unshift File.join(crew_local_repo_root, 'lib')
require_relative '../lib/color'
require_relative '../lib/package'
require_relative '../lib/package_utils'
OUTPUT_JSON = ARGV.include?('-j') || ARGV.include?('--json')
UPDATE_PACKAGE_FILES = ARGV.include?('-u') || ARGV.include?('--update-package-files') UPDATE_PACKAGE_FILES = ARGV.include?('-u') || ARGV.include?('--update-package-files')
VERBOSE = ARGV.include?('-v') || ARGV.include?('--verbose') VERBOSE = ARGV.include?('-v') || ARGV.include?('--verbose')
bc_updated = {} bc_updated = {}
pkg_names = {}
version_line_string = {}
versions_updated = {} versions_updated = {}
versions = []
# Some packges need manual adjustments of URLS for different versions.
automatic_version_update_excluded_packages = Set[
{ pkg_name: 'cf', comments: 'Uses a dynamic source package URL.' },
{ pkg_name: 'cursor', comments: 'Uses a dynamic source package URL.' }
]
excluded_pkgs = automatic_version_update_excluded_packages.map { |h| h[:pkg_name] }
exclusion_regex = "(#{excluded_pkgs.join('|')})"
# Some packages have different names in anitya.
@anitya_package_name_mappings = Set[
{ pkg_name: 'cvs', anitya_pkg: 'cvs-stable', comments: '' }
].to_h { |h| [h[:pkg_name], h[:anitya_pkg]] }
def get_version(name, homepage, source) def get_version(name, homepage, source)
# Determine if the source is a GitHub repository. # Determine if the source is a GitHub repository.
@@ -58,8 +54,8 @@ def get_version(name, homepage, source)
end end
end end
end end
anitya_name_mapping_idx = @anitya_package_name_mappings.keys.find_index { |i| i == name } anitya_name_mapping_idx = CREW_ANITYA_PACKAGE_NAME_MAPPINGS.keys.find_index { |i| i == name }
anitya_name = anitya_name_mapping_idx.nil? ? name : @anitya_package_name_mappings.values[anitya_name_mapping_idx] anitya_name = anitya_name_mapping_idx.nil? ? name : CREW_ANITYA_PACKAGE_NAME_MAPPINGS.values[anitya_name_mapping_idx]
anitya_id = get_anitya_id(anitya_name, homepage) anitya_id = get_anitya_id(anitya_name, homepage)
# If we weren't able to get an Anitya ID, return early here to save time and headaches # If we weren't able to get an Anitya ID, return early here to save time and headaches
return if anitya_id.nil? return if anitya_id.nil?
@@ -127,84 +123,128 @@ if ARGV.length.positive? && !(ARGV.length == 1 && OPTIONS.include?(ARGV[0]))
arg = arg.gsub('.rb', '') arg = arg.gsub('.rb', '')
next unless arg =~ /^[0-9a-zA-Z\_\*]+$/ next unless arg =~ /^[0-9a-zA-Z\_\*]+$/
if arg.include?('*') if arg.include?('*')
Dir["../packages/#{arg}.rb"].each do |filename| Dir[File.join(crew_local_repo_root, "packages/#{arg}.rb")].each do |filename|
filelist.push filename filelist.push filename
end end
else else
filename = "../packages/#{arg}.rb" filename = File.join(crew_local_repo_root, "packages/#{arg}.rb")
filelist.push filename if File.exist?(filename) filelist.push filename if File.exist?(filename)
end end
end end
else else
Dir['../packages/*.rb'].each do |filename| Dir[File.join(crew_local_repo_root, 'packages/*.rb')].each do |filename|
filelist.push filename filelist.push filename
end end
end end
if filelist.length.positive? if filelist.length.positive?
puts "#{'Package'.ljust(35)}#{'Status'.ljust(20)}#{'Current'.ljust(20)}Upstream" max_pkg_name_length = File.basename(filelist.max_by(&:length)).length - 3
puts "#{'-------'.ljust(35)}#{'------'.ljust(20)}#{'-------'.ljust(20)}--------" package_field_length = [max_pkg_name_length, 7].max + 4
status_field_length = 20
version_field_length = 16
puts "#{'Package'.ljust(package_field_length)}#{'Status'.ljust(status_field_length)}#{'Current'.ljust(version_field_length)}Upstream" unless OUTPUT_JSON
puts "#{'-------'.ljust(package_field_length)}#{'------'.ljust(status_field_length)}#{'-------'.ljust(version_field_length)}--------" unless OUTPUT_JSON
filelist.each do |filename| filelist.each do |filename|
pkg = Package.load_package(filename) pkg = Package.load_package(filename)
# Instead of typing out the name of every python package, we just use a regex here. pkg_names[pkg.name.to_sym] = pkg.name
# Also, we annotate some packages to let us know that they won't work here. version_line_string[pkg.name.to_sym] = ''
if pkg.name.match?(/py3\S+/) || pkg.no_upstream_update? # We annotate some packages to let us know that they won't work here.
puts pkg.name.ljust(35) + 'noupdate'.lightred if VERBOSE versions_updated[pkg.name.to_sym] = 'Up to date.' if pkg.no_upstream_update?
next
end
# We skip fake packages.
if pkg.is_fake? if pkg.is_fake?
puts pkg.name.ljust(35) + 'fake'.lightred if VERBOSE versions_updated[pkg.name.to_sym] = 'Fake'
next next
end end
# Skip ruby and pip buildsystem packages. if %w[RUBY].include?(pkg.superclass.to_s)
if %w[RUBY Pip].include?(pkg.superclass.to_s) gem_name = pkg.name.sub('ruby_', '')
puts pkg.name.ljust(35) + 'skipped'.lightred if VERBOSE # We replace all dashes with underscores in our initial package names, but some gems actually use underscores, so we need special cases.
next # This list was created by looking at what packages were listed as not having updates in rubygems, and then looking up the upstream name for them.
if %w[
connection_pool error_highlight jaro_winkler
lint_roller method_source mini_mime multi_xml mutex_m
power_assert regexp_parser repl_type_completor ruby2_keywords
syntax_suggest
].include?(gem_name)
# These gems used underscores originally, so don't replace anything
elsif gem_name == 'language_server_protocol'
# These gems have an underscore then a dash, but there's only one, so we hardcode the logic for now.
gem_name = 'language_server-protocol'
elsif gem_name == 'unicode_display_width'
# These gems have a dash then an underscore, but there's only one, so we hardcode the logic for now.
gem_name = 'unicode-display_width'
else
# In the common case, the gem name used only dashes, which we all replaced with underscores.
gem_name.gsub!('_', '-')
end
upstream_version = JSON.parse(Net::HTTP.get(URI("https://rubygems.org/api/v1/versions/#{gem_name}/latest.json")))['version']
elsif %w[Pip].include?(pkg.superclass.to_s)
versions_updated[pkg.name.to_sym] = 'Not Found.' if pkg.name[/#{CREW_AUTOMATIC_VERSION_UPDATE_EXCLUSION_REGEX}/]
pip_name = pkg.name.sub('py3_', '').gsub('_', '-')
begin
upstream_version = `pip index versions #{'--pre' if pkg.prerelease?} #{pip_name} 2>/dev/null`.match(/#{Regexp.escape(pip_name)} \(([^)]+)\)/)[1]
rescue NoMethodError
versions_updated[pkg.name.to_sym] = 'Not Found.'
end
else
# Get the upstream version.
upstream_version = get_version(pkg.name.tr('_', '-'), pkg.homepage, pkg.source_url)
end end
# Get the upstream version.
upstream_version = get_version(pkg.name.tr('_', '-'), pkg.homepage, pkg.source_url)
# Some packages don't work with this yet, so gracefully exit now rather than throwing false positives. # Some packages don't work with this yet, so gracefully exit now rather than throwing false positives.
if upstream_version.nil? || upstream_version.to_s.chomp == 'null' versions_updated[pkg.name.to_sym] = 'Not Found.' if upstream_version.nil? || upstream_version.to_s.chomp == 'null'
puts pkg.name.ljust(35) + 'notfound'.lightred if VERBOSE
next
end
# Bail out if we arent verbose and so dont want to print packages that are up to date. unless upstream_version.nil?
next if Libversion.version_compare2(PackageUtils.get_clean_version(pkg.version), upstream_version) >= 0 && !VERBOSE versions_updated[pkg.name.to_sym] = 'Up to date.' if (Libversion.version_compare2(PackageUtils.get_clean_version(pkg.version), upstream_version) >= 0) && versions_updated[pkg.name.to_sym] != 'Not Found.'
# Print the package name. if Libversion.version_compare2(PackageUtils.get_clean_version(pkg.version), upstream_version) == -1
print pkg.name.ljust(35) if UPDATE_PACKAGE_FILES && !pkg.name[/#{CREW_AUTOMATIC_VERSION_UPDATE_EXCLUSION_REGEX}/]
# Print the package update status. sed_cmd = <<~SED
if Libversion.version_compare2(PackageUtils.get_clean_version(pkg.version), upstream_version) >= 0 grep "^ version '#{PackageUtils.get_clean_version(pkg.version)}'" #{filename} && sed "s,^ version '#{PackageUtils.get_clean_version(pkg.version)}', version '#{upstream_version.chomp}'," #{filename} > #{filename}.tmp && mv #{filename}.tmp #{filename}
print 'uptodate'.ljust(20).lightgreen SED
elsif Libversion.version_compare2(PackageUtils.get_clean_version(pkg.version), upstream_version) == -1 `#{sed_cmd}`
if UPDATE_PACKAGE_FILES && !pkg.name[/#{exclusion_regex}/] versions_updated[pkg.name.to_sym] = $CHILD_STATUS.success?
sed_cmd = <<~SED
grep "^ version '#{PackageUtils.get_clean_version(pkg.version)}'" #{filename} && sed "s,^ version '#{PackageUtils.get_clean_version(pkg.version)}', version '#{upstream_version.chomp}'," #{filename} > #{filename}.tmp && mv #{filename}.tmp #{filename}
SED
`#{sed_cmd}`
versions_updated[pkg.name.to_sym] = $CHILD_STATUS.success?
binary_compression_sed_cmd = <<~BC_SED binary_compression_sed_cmd = <<~BC_SED
sed "s,^ binary_compression 'tar.xz', binary_compression 'tar.zst'," #{filename} > #{filename}.tmp && mv #{filename}.tmp #{filename} sed "s,^ binary_compression 'tar.xz', binary_compression 'tar.zst'," #{filename} > #{filename}.tmp && mv #{filename}.tmp #{filename}
BC_SED BC_SED
if pkg.binary_compression == 'tar.xz' && !pkg.no_zstd? if pkg.binary_compression == 'tar.xz' && !pkg.no_zstd?
`#{binary_compression_sed_cmd}` `#{binary_compression_sed_cmd}`
bc_updated[pkg.name.to_sym] = $CHILD_STATUS.success? bc_updated[pkg.name.to_sym] = $CHILD_STATUS.success?
end
end
if UPDATE_PACKAGE_FILES && versions_updated[pkg.name.to_sym]
versions_updated[pkg.name.to_sym] = 'Updated.'
else
versions_updated[pkg.name.to_sym] = pkg.name[/#{CREW_AUTOMATIC_VERSION_UPDATE_EXCLUSION_REGEX}/] ? 'Update manually.' : 'Outdated.'
FileUtils.rm_f "#{filename}.tmp"
end end
end end
if UPDATE_PACKAGE_FILES && versions_updated[pkg.name.to_sym]
print 'updated for build'.ljust(20).blue
else
print pkg.name[/#{exclusion_regex}/] ? 'Update MANUALLY.'.ljust(20).red : 'outdated'.ljust(20).yellow
FileUtils.rm_f "#{filename}.tmp"
end
end end
# Print the package versions. # puts PackageUtils.get_clean_version(pkg.version).ljust(status_field_length) + upstream_version unless OUTPUT_JSON
puts PackageUtils.get_clean_version(pkg.version).ljust(20) + upstream_version version_status_string = ''.ljust(status_field_length)
print "failed sed cmd: #{sed_cmd}".ljust(20).yellow if versions_updated[pkg.name.to_sym].to_s == 'false' case versions_updated[pkg.name.to_sym]
print "failed sed cmd: #{binary_compression_sed_cmd}".ljust(20).yellow if bc_updated[pkg.name.to_sym].to_s == 'false' when 'Fake'
version_status_string = 'Fake'.ljust(status_field_length).lightred
upstream_version = ''
when 'Not Found.'
version_status_string = 'Not Found.'.ljust(status_field_length).lightred
upstream_version = ''
when 'Outdated.'
version_status_string = 'Outdated.'.ljust(status_field_length).yellow
when 'Update manually.'
version_status_string = 'Update manually.'.ljust(status_field_length).red
when 'Updated.'
version_status_string = 'Updated.'.ljust(status_field_length).blue
when 'Up to date.'
version_status_string = 'Up to date.'.ljust(status_field_length).lightgreen
end
cleaned_pkg_version = PackageUtils.get_clean_version(pkg.version)
versions.push(package: pkg.name, update_status: versions_updated[pkg.name.to_sym], version: cleaned_pkg_version, upstream_version: upstream_version.chomp)
version_line_string[pkg.name.to_sym] = "#{pkg.name.ljust(package_field_length)}#{version_status_string}#{cleaned_pkg_version.ljust(version_field_length)}#{upstream_version}\n"
print version_line_string[pkg.name.to_sym] unless OUTPUT_JSON
print "failed sed cmd: #{sed_cmd}".ljust(sed_cmd.length).yellow if !OUTPUT_JSON && (versions_updated[pkg.name.to_sym].to_s == 'false')
print "failed sed cmd: #{binary_compression_sed_cmd}".ljust(binary_compression_sed_cmd.length).yellow if !OUTPUT_JSON && (bc_updated[pkg.name.to_sym].to_s == 'false')
end end
puts versions.to_json if OUTPUT_JSON
end end