Skip to content

Concurrently renames all files and directories in a specified directory according to the user specified rule

Notifications You must be signed in to change notification settings

Singularitty/ConcurrentRecursiveRenamer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 

Repository files navigation

ConcurrentRecursiveRenamer

Concurrently renames all files and directories in a specified directory according to the user specified rule

Usage

To run the program simply use:

go run ConcurrentRecursiveRenamer.go directory target_string replacement_string

The program will recursively go through the specified directory and rename each file by replacing the target_string with the replacement_string.

E.g.:

Before usage:
├── root_dir
│ ├── branch_1
│ │ ├── branch_1_doc.txt
│ ├── branch_2
│ │ ├── branch_2_2
│ │ │ ├── deep_branch.c
│ ├── document.txt
│ ├── images

go run ConcurrentRecursiveRenamer.go root_dir branch child

After usage:

├── root_dir
│ ├── child_1
│ │ ├── child_1_doc.txt
│ ├── child_2
│ │ ├── child_2_2
│ │ │ ├── deep_child.c
│ ├── document.txt
│ ├── images

When the program is ran, the main thread spawns a go routine for each file in the specified directory.
Each go routine will then calculate a new path for the current file and if it is a directory it will spawn a new go routine which will do the same thing recursively until all the files of the root directory have been explored.
When a go routine reaches a file that isn't a directory it sends the new calculated path to the go routine that originally spawned it, resulting in all the new paths being sent to the main thread. Main then orders the paths by depth and renames then sequentially to not cause any naming conflicts.

About

Concurrently renames all files and directories in a specified directory according to the user specified rule

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages