Optimized hashing, pure, bsr etc.
This commit is contained in:
@@ -34,10 +34,9 @@ repositories:
|
|||||||
alias: bsr
|
alias: bsr
|
||||||
provider: github.com
|
provider: github.com
|
||||||
repository: bulk-string-replacer
|
repository: bulk-string-replacer
|
||||||
command: python replace_string.py
|
|
||||||
description: Bulk String Replacer CLI (bsr) is a command-line tool for efficiently searching and replacing strings in file names, folder names, and file contents across directories. It's perfect for bulk updates and streamlining your workflow.
|
description: Bulk String Replacer CLI (bsr) is a command-line tool for efficiently searching and replacing strings in file names, folder names, and file contents across directories. It's perfect for bulk updates and streamlining your workflow.
|
||||||
homepage: https://github.com/kevinveenbirkenbach/bulk-string-replacer
|
homepage: https://github.com/kevinveenbirkenbach/bulk-string-replacer
|
||||||
verified: ce964188786d4d2d6f046de6e070fed1443ccc73
|
verified: daf45389383ef6b3d6569d63eb3e052ab811916d
|
||||||
- account: kevinveenbirkenbach
|
- account: kevinveenbirkenbach
|
||||||
alias: imgrszr
|
alias: imgrszr
|
||||||
provider: github.com
|
provider: github.com
|
||||||
@@ -219,4 +218,4 @@ repositories:
|
|||||||
Bulk Rename is a Python-based CLI tool that renames files in bulk by replacing specified substrings in file names.
|
Bulk Rename is a Python-based CLI tool that renames files in bulk by replacing specified substrings in file names.
|
||||||
It supports both recursive and non-recursive renaming with verbose output.
|
It supports both recursive and non-recursive renaming with verbose output.
|
||||||
homepage: https://github.com/kevinveenbirkenbach/bulk-rename
|
homepage: https://github.com/kevinveenbirkenbach/bulk-rename
|
||||||
verified: dc2ecefd3b7a64f5dcbd808fed5f53886a766315
|
verified: f76b29720edf2df5760070e34eacae23beb9d3a7
|
||||||
@@ -1,9 +1,11 @@
|
|||||||
import os
|
import os
|
||||||
from pkgmgr.get_repo_identifier import get_repo_identifier
|
from pkgmgr.get_repo_identifier import get_repo_identifier
|
||||||
from pkgmgr.get_repo_dir import get_repo_dir
|
from pkgmgr.get_repo_dir import get_repo_dir
|
||||||
|
|
||||||
def list_repositories(all_repos, repositories_base_dir, bin_dir, search_filter="", status_filter=""):
|
def list_repositories(all_repos, repositories_base_dir, bin_dir, search_filter="", status_filter=""):
|
||||||
"""
|
"""
|
||||||
List all repositories with their attributes and status information.
|
Lists all repositories with their attributes and status information.
|
||||||
|
The repositories are sorted in ascending order by their identifier.
|
||||||
|
|
||||||
Parameters:
|
Parameters:
|
||||||
all_repos (list): List of repository configurations.
|
all_repos (list): List of repository configurations.
|
||||||
@@ -33,7 +35,10 @@ def list_repositories(all_repos, repositories_base_dir, bin_dir, search_filter="
|
|||||||
"Installable": "\033[38;5;82m" # Light Green (extended)
|
"Installable": "\033[38;5;82m" # Light Green (extended)
|
||||||
}
|
}
|
||||||
|
|
||||||
for repo in all_repos:
|
# Sort all repositories by their identifier in ascending order.
|
||||||
|
sorted_repos = sorted(all_repos, key=lambda repo: get_repo_identifier(repo, all_repos))
|
||||||
|
|
||||||
|
for repo in sorted_repos:
|
||||||
# Combine all attribute values into one string for filtering.
|
# Combine all attribute values into one string for filtering.
|
||||||
repo_text = " ".join(str(v) for v in repo.values()).lower()
|
repo_text = " ".join(str(v) for v in repo.values()).lower()
|
||||||
if search_filter and search_filter not in repo_text:
|
if search_filter and search_filter not in repo_text:
|
||||||
@@ -83,10 +88,10 @@ def list_repositories(all_repos, repositories_base_dir, bin_dir, search_filter="
|
|||||||
# Loop through all attributes.
|
# Loop through all attributes.
|
||||||
for key, value in repo.items():
|
for key, value in repo.items():
|
||||||
formatted_value = str(value)
|
formatted_value = str(value)
|
||||||
# Special formatting for "verified" attribute (yellow).
|
# Special formatting for the "verified" attribute (yellow).
|
||||||
if key == "verified" and value:
|
if key == "verified" and value:
|
||||||
formatted_value = f"\033[1;33m{value}\033[0m"
|
formatted_value = f"\033[1;33m{value}\033[0m"
|
||||||
# Special formatting for "ignore" flag (red if True).
|
# Special formatting for the "ignore" flag (red if True).
|
||||||
if key == "ignore" and value:
|
if key == "ignore" and value:
|
||||||
formatted_value = f"\033[1;31m{value}\033[0m"
|
formatted_value = f"\033[1;31m{value}\033[0m"
|
||||||
if key == "description":
|
if key == "description":
|
||||||
|
|||||||
@@ -9,8 +9,9 @@ def pull_with_verification(selected_repos, repositories_base_dir, all_repos, ext
|
|||||||
Executes "git pull" for each repository with hash verification.
|
Executes "git pull" for each repository with hash verification.
|
||||||
|
|
||||||
For repositories with a 'verified' hash in the configuration, this function first
|
For repositories with a 'verified' hash in the configuration, this function first
|
||||||
checks the current commit hash. If it does not match the verified hash, the user is prompted
|
retrieves the remote commit hash (using 'git ls-remote origin HEAD'). If the remote hash
|
||||||
to confirm the pull (unless --no-verification is set, in which case the pull proceeds automatically).
|
does not match the verified hash, the user is prompted to confirm the pull (unless --no-verification
|
||||||
|
is set, in which case the pull proceeds automatically).
|
||||||
"""
|
"""
|
||||||
for repo in selected_repos:
|
for repo in selected_repos:
|
||||||
repo_identifier = get_repo_identifier(repo, all_repos)
|
repo_identifier = get_repo_identifier(repo, all_repos)
|
||||||
@@ -20,17 +21,18 @@ def pull_with_verification(selected_repos, repositories_base_dir, all_repos, ext
|
|||||||
continue
|
continue
|
||||||
|
|
||||||
verified_hash = repo.get("verified")
|
verified_hash = repo.get("verified")
|
||||||
current_hash = ""
|
remote_hash = ""
|
||||||
try:
|
try:
|
||||||
result = subprocess.run("git rev-parse HEAD", cwd=repo_dir, shell=True, check=True,
|
result = subprocess.run("git ls-remote origin HEAD", cwd=repo_dir, shell=True, check=True,
|
||||||
stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True)
|
stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True)
|
||||||
current_hash = result.stdout.strip()
|
# The first token in the output is the remote HEAD commit hash.
|
||||||
|
remote_hash = result.stdout.split()[0].strip()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(f"Error retrieving current commit for {repo_identifier}: {e}")
|
print(f"Error retrieving remote commit for {repo_identifier}: {e}")
|
||||||
|
|
||||||
proceed = True
|
proceed = True
|
||||||
if not no_verification and verified_hash and current_hash != verified_hash:
|
if not no_verification and verified_hash and remote_hash and remote_hash != verified_hash:
|
||||||
print(f"Warning: For {repo_identifier}, the current hash ({current_hash}) does not match the verified hash ({verified_hash}).")
|
print(f"Warning: For {repo_identifier}, the remote hash ({remote_hash}) does not match the verified hash ({verified_hash}).")
|
||||||
choice = input("Proceed with 'git pull'? (y/N): ").strip().lower()
|
choice = input("Proceed with 'git pull'? (y/N): ").strip().lower()
|
||||||
if choice != "y":
|
if choice != "y":
|
||||||
proceed = False
|
proceed = False
|
||||||
|
|||||||
Reference in New Issue
Block a user