carrooi / cloner
Copy files or directories from neon configuration
Requires
- kdyby/console: ~2.2
- nette/di: ~2.2
- nette/finder: ~2.2
- nette/utils: ~2.2
Requires (Dev)
- mockery/mockery: ~0.9
- nette/application: ~2.2
- nette/bootstrap: ~2.2
- nette/mail: ~2.2
- nette/safe-stream: ~2.2
- nette/tester: ~1.3.0
This package is auto-updated.
Last update: 2025-01-06 03:50:23 UTC
README
Extension for auto-copying assets or any other files to your project.
Installation
$ composer require carrooi/cloner
$ composer update
Then just enable nette extension in your config.neon:
extensions: cloner: Carrooi\Cloner\DI\ClonerExtension
Configuration
extensions: cloner: Carrooi\Cloner\DI\ClonerExtension cloner: paths: - [%appDir%/../www/node_modules/test/lib, %appDir%/../www/js] - [%appDir%/../www/node_modules/jquery/jquery.js, %appDir%/../www/js/jquery.js]
There you can see simple configuration which will copy everything from node_modules/test/lib
directory to our js
directory also with jquery.js
file.
Each "source" / "target" path must be in one array (not in pair), but there can be many sources / one target paths.
Take a look at testing configuration for all possible path options.
Running
This extension don't do anything by default, so you have to enable it.
cloner: autoRun: true
Also you have to be in debug
mode, or set debug
options to true
.
Now at every request all configured paths will be checked and files updated.
Update command
It is not the best idea to check all files at each request so there is terminal command for that.
$ php www/index.php cloner:run --force
If you remove --force
option, Cloner will just print found different files which needs to be updated.
You can also register this command as post install/update script in your composer.json. Then it will be started automatically by composer after each update or install. See more at composer documentation.
Changelog
-
1.0.0
- First version
-
1.0.1
- Checking for changes with filemtime, not hash_file