lib/makit/directory.rb in makit-0.0.56 vs lib/makit/directory.rb in makit-0.0.57
- old
+ new
@@ -1,200 +1,200 @@
-# frozen_string_literal: true
-
-require "find"
-require "pathname"
-#require "gitignore"
-
-# This module provides classes for the Makit gem.
-module Makit
- # This class provide methods for working with Directories/
- #
- # Example:
- #
- # Makit::Directory.find_directory_with_pattern("/home/user", "*.rb")
- #
- class Directory
- def self.get_line_count(file)
- line_count = 0
- File.foreach(file) { line_count += 1 }
- line_count
- end
-
- def self.find_directory_with_patterns(starting_directory, patterns)
- patterns.each do |pattern|
- result = find_directory_with_pattern(starting_directory, pattern)
- if (Dir.exist?(result))
- return result
- end
- end
-
- nil
- end
-
- def self.find_directory_with_pattern(starting_directory, pattern)
- current_directory = File.expand_path(starting_directory)
-
- loop do
- return current_directory if contains_pattern?(current_directory, pattern)
-
- parent_directory = File.dirname(current_directory)
- break if parent_directory == current_directory # Reached the root directory
-
- current_directory = parent_directory
- end
-
- nil
- end
-
- def self.contains_pattern?(directory, pattern)
- Dir.foreach(directory) do |entry|
- next if [".", ".."].include?(entry)
- return true if File.fnmatch(pattern, entry)
- end
- false
- end
-
- def self.get_size(directory)
- total_size = 0
-
- Find.find(directory) do |file|
- total_size += File.size(file) if File.file?(file)
- end
-
- total_size
- end
-
- def self.get_humanized_size(size_in_bytes, precision = 2)
- end
-
- def self.zip_source_files(directory_path, zip_file_name)
- raise ArgumentError, "Directory path cannot be nil" if directory_path.nil?
- raise ArgumentError, "Zip file name cannot be nil or empty" if zip_file_name.nil? || zip_file_name.strip.empty?
-
- unless Dir.exist?(directory_path)
- raise ArgumentError, "Directory '#{directory_path}' does not exist."
- end
-
- tracked_files = get_git_tracked_files(directory_path)
-
- if tracked_files.empty?
- raise "No tracked files found in the directory."
- end
-
- Zip::File.open(zip_file_name, Zip::File::CREATE) do |zipfile|
- tracked_files.each do |file|
- full_path = File.join(directory_path, file)
- if File.exist?(full_path)
- zipfile.add(file, full_path)
- end
- end
- end
- end
-
- def self.get_git_tracked_files(directory_path)
- #raise "do not use this method"
- #output, status = Open3.capture2("git ls-files directory", chdir: directory_path)
- #raise "Failed to list git-tracked files" unless status.success?
- #command = "git ls-files #{directory_path}".run
-
- #command.output.split("\n")
- `git ls-files #{directory_path}`.split("\n")
- end
-
- def self.get_newest_git_file(directory_path)
- get_git_tracked_files(directory_path).select { |f| File.file?(f) }.max_by { |f| File.mtime(f) }
- end
-
- def self.get_newest_git_file_timestamp(directory_path)
- get_newest_git_file(directory_path).nil? ? Time.now : File.mtime(get_newest_git_file(directory_path))
- end
-
- def self.get_newest_file_timestamp(directory_path)
- newest_file = get_git_tracked_files(directory_path).select { |f| File.file?(f) }.max_by { |f| File.mtime(f) }
- newest_file.nil? ? Time.now : File.mtime(newest_file)
- end
-
- # Normalize the path by removing any leading or trailing slashes
- # and replacing any backslashes with forward slashes
- def self.normalize(path)
- path = path.gsub("\\", "/")
- #path = path[1..-1] if path.start_with?("/")
- path = path[0..-2] if path.end_with?("/")
- path
- end
-
- # for a given path, collect all the subdirectories that match a version pattern.
- # for example 2.57.0, 2.62, or 2.65.0
- def self.get_version_directories(path)
- version_directories = []
- Dir.foreach(path) do |entry|
- next if [".", ".."].include?(entry)
- version_directories << entry if entry.match?(/^\d+\.\d+\.\d+$/)
- end
- version_directories
- end
-
- def self.modified(path)
- self.get_newest_file(path)
- end
- # for a given path, get the most recent file change date for any file in the directory
- def self.get_latest_file_change_date(path)
- # loop over all files in the directory
- latest_date = nil
- Find.find(path) do |file|
- if File.file?(file)
- date = File.mtime(file)
- latest_date = date if latest_date.nil? || date > latest_date
- end
- end
- latest_date
- end
-
- # for a given path, return the filename of the most recently modified file
- def self.get_newest_file(path)
- newest_file = nil
- latest_date = nil
- if (Dir.exist?(path))
- Find.find(path) do |file|
- if File.file?(file)
- date = File.mtime(file)
- latest_date = date if latest_date.nil? || date > latest_date
- newest_file = file if date == latest_date
- end
- end
- end
- newest_file
- end
-
- def self.copy(src_dir, dst_dir, verbose = false)
- FileUtils.cp_r(src_dir, dst_dir, verbose: verbose)
- end
-
- def self.generate_manifest(dir)
- if File.exist?("#{dir}/manifest.txt")
- File.delete("#{dir}/manifest.txt")
- end
- File.open("#{dir}/manifest.txt", "w") do |f|
- Dir.glob("#{dir}/**/*").each do |file|
- next if File.directory?(file)
- f.puts file.sub("#{dir}/", "")
- end
- end
- end
-
- def self.remove_empty_directories(dir)
- Find.find(dir) do |path|
- if File.directory?(path) && Dir.empty?(path)
- FileUtils.rm_rf(path)
- end
- end
- end
-
- def self.remove_empty_directories_recursively(dir)
- Find.find(dir) do |path|
- if File.directory?(path) && Dir.empty?(path)
- FileUtils.rm_rf(path)
- end
- end
- end
- end
-end
+# frozen_string_literal: true
+
+require "find"
+require "pathname"
+#require "gitignore"
+
+# This module provides classes for the Makit gem.
+module Makit
+ # This class provide methods for working with Directories/
+ #
+ # Example:
+ #
+ # Makit::Directory.find_directory_with_pattern("/home/user", "*.rb")
+ #
+ class Directory
+ def self.get_line_count(file)
+ line_count = 0
+ File.foreach(file) { line_count += 1 }
+ line_count
+ end
+
+ def self.find_directory_with_patterns(starting_directory, patterns)
+ patterns.each do |pattern|
+ result = find_directory_with_pattern(starting_directory, pattern)
+ if (Dir.exist?(result))
+ return result
+ end
+ end
+
+ nil
+ end
+
+ def self.find_directory_with_pattern(starting_directory, pattern)
+ current_directory = File.expand_path(starting_directory)
+
+ loop do
+ return current_directory if contains_pattern?(current_directory, pattern)
+
+ parent_directory = File.dirname(current_directory)
+ break if parent_directory == current_directory # Reached the root directory
+
+ current_directory = parent_directory
+ end
+
+ nil
+ end
+
+ def self.contains_pattern?(directory, pattern)
+ Dir.foreach(directory) do |entry|
+ next if [".", ".."].include?(entry)
+ return true if File.fnmatch(pattern, entry)
+ end
+ false
+ end
+
+ def self.get_size(directory)
+ total_size = 0
+
+ Find.find(directory) do |file|
+ total_size += File.size(file) if File.file?(file)
+ end
+
+ total_size
+ end
+
+ def self.get_humanized_size(size_in_bytes, precision = 2)
+ end
+
+ def self.zip_source_files(directory_path, zip_file_name)
+ raise ArgumentError, "Directory path cannot be nil" if directory_path.nil?
+ raise ArgumentError, "Zip file name cannot be nil or empty" if zip_file_name.nil? || zip_file_name.strip.empty?
+
+ unless Dir.exist?(directory_path)
+ raise ArgumentError, "Directory '#{directory_path}' does not exist."
+ end
+
+ tracked_files = get_git_tracked_files(directory_path)
+
+ if tracked_files.empty?
+ raise "No tracked files found in the directory."
+ end
+
+ Zip::File.open(zip_file_name, Zip::File::CREATE) do |zipfile|
+ tracked_files.each do |file|
+ full_path = File.join(directory_path, file)
+ if File.exist?(full_path)
+ zipfile.add(file, full_path)
+ end
+ end
+ end
+ end
+
+ def self.get_git_tracked_files(directory_path)
+ #raise "do not use this method"
+ #output, status = Open3.capture2("git ls-files directory", chdir: directory_path)
+ #raise "Failed to list git-tracked files" unless status.success?
+ #command = "git ls-files #{directory_path}".run
+
+ #command.output.split("\n")
+ `git ls-files #{directory_path}`.split("\n")
+ end
+
+ def self.get_newest_git_file(directory_path)
+ get_git_tracked_files(directory_path).select { |f| File.file?(f) }.max_by { |f| File.mtime(f) }
+ end
+
+ def self.get_newest_git_file_timestamp(directory_path)
+ get_newest_git_file(directory_path).nil? ? Time.now : File.mtime(get_newest_git_file(directory_path))
+ end
+
+ def self.get_newest_file_timestamp(directory_path)
+ newest_file = get_git_tracked_files(directory_path).select { |f| File.file?(f) }.max_by { |f| File.mtime(f) }
+ newest_file.nil? ? Time.now : File.mtime(newest_file)
+ end
+
+ # Normalize the path by removing any leading or trailing slashes
+ # and replacing any backslashes with forward slashes
+ def self.normalize(path)
+ path = path.gsub("\\", "/")
+ #path = path[1..-1] if path.start_with?("/")
+ path = path[0..-2] if path.end_with?("/")
+ path
+ end
+
+ # for a given path, collect all the subdirectories that match a version pattern.
+ # for example 2.57.0, 2.62, or 2.65.0
+ def self.get_version_directories(path)
+ version_directories = []
+ Dir.foreach(path) do |entry|
+ next if [".", ".."].include?(entry)
+ version_directories << entry if entry.match?(/^\d+\.\d+\.\d+$/)
+ end
+ version_directories
+ end
+
+ def self.modified(path)
+ self.get_newest_file(path)
+ end
+ # for a given path, get the most recent file change date for any file in the directory
+ def self.get_latest_file_change_date(path)
+ # loop over all files in the directory
+ latest_date = nil
+ Find.find(path) do |file|
+ if File.file?(file)
+ date = File.mtime(file)
+ latest_date = date if latest_date.nil? || date > latest_date
+ end
+ end
+ latest_date
+ end
+
+ # for a given path, return the filename of the most recently modified file
+ def self.get_newest_file(path)
+ newest_file = nil
+ latest_date = nil
+ if (Dir.exist?(path))
+ Find.find(path) do |file|
+ if File.file?(file)
+ date = File.mtime(file)
+ latest_date = date if latest_date.nil? || date > latest_date
+ newest_file = file if date == latest_date
+ end
+ end
+ end
+ newest_file
+ end
+
+ def self.copy(src_dir, dst_dir, verbose = false)
+ FileUtils.cp_r(src_dir, dst_dir, verbose: verbose)
+ end
+
+ def self.generate_manifest(dir)
+ if File.exist?("#{dir}/manifest.txt")
+ File.delete("#{dir}/manifest.txt")
+ end
+ File.open("#{dir}/manifest.txt", "w") do |f|
+ Dir.glob("#{dir}/**/*").each do |file|
+ next if File.directory?(file)
+ f.puts file.sub("#{dir}/", "")
+ end
+ end
+ end
+
+ def self.remove_empty_directories(dir)
+ Find.find(dir) do |path|
+ if File.directory?(path) && Dir.empty?(path)
+ FileUtils.rm_rf(path)
+ end
+ end
+ end
+
+ def self.remove_empty_directories_recursively(dir)
+ Find.find(dir) do |path|
+ if File.directory?(path) && Dir.empty?(path)
+ FileUtils.rm_rf(path)
+ end
+ end
+ end
+ end
+end