Metadata-Version: 2.1
Name: copy-to
Version: 1.3.1
Summary: A little commandline tool to copy and paste multiple files and directories to single directory with use of configuration
Author-email: Stan Nys <stan96@duck.com>
Project-URL: Homepage, https://github.com/excited-bore/copy-to
Project-URL: Bug Tracker, https://github.com/excited-bore/copy-to/issues
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.7
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: argcomplete>=3.2.1
Requires-Dist: GitPython>=3.1.14
Requires-Dist: prompt_toolkit>=3.0.20

# copy-to

A little python script i use in conjunction with git so you can easily copy config files from anywhere in an instant to do whatever with!

Depends on [argcomplete](https://pypi.org/project/argcomplete/), [GitPython](https://pypi.org/project/GitPython/), [prompt_toolkit](https://pypi.org/project/prompt_toolkit/)

Install it with:

```
pipx install copy-to
```
Try running it once if autocompletions aren't working

``` 
sudo activate-global-python-argcomplete
```
for installing pythoncompletions globally.

Add a pairset of destination folder - source files and/or directories with  
```
copy-to add myname destination_folder sourcefile1 (sourcefolder1 sourcefile2 sourcefile3 sourcefolder2/*) ...
```

List configured paths and files with  
```
copy-to list myname
```  
or just  
```
copy-to list
```
'names' and 'groups' to list all names and groups respectively  
You can also use 'all' to list/run all regular names  


Copy the files to their destination by running  
```
copy-to run myname1 (myname2)
```

Or copy the files back to source by running  
```
copy-to run-reverse myname1 (myname2)
```

Run and run-reverse can run without arguments when present in a git repository that has configured copy-to. Does not work with global gitconfig.  

```
[copy-to]
    run = myname1 myname2
```

This can be setup with `copy-to add myname` and `copy-to set-git myname` or  
`copy-to add myname` and `copy-to run` after wich a prompt will ask if you want to set it up with git.  


Delete set of dest/src by name with  
```
copy-to delete myname1 (myname2)
```

Add sources with  
```
copy-to add_source myname folder1 file1
```

Delete source by index with
```
copy-to delete_source myname 1 4 7
```

Reset source and destination folders
```
copy-to reset_source myname
copy-to reset_destination myname newDest
```

Groups are based on names. For copying to multiple directories in one go.
Takes up 'group' as config namespace.

Add groupname
```
copy-to add_group mygroupname myname1 myname2
```

Delete groupname
```
copy-to delete_group mygroupname
```

Configuration files at `~/.config/copy-to/confs.json` for Linux  

Windows and mac not tested
