2017 © Pedro Peláez
 

library phing-copy-files-task

Copy files with better control over copying than the default Phing CopyTask

image

vasek-purchart/phing-copy-files-task

Copy files with better control over copying than the default Phing CopyTask

  • Friday, September 22, 2017
  • by VasekPurchart
  • Repository
  • 2 Watchers
  • 2 Stars
  • 2,356 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 3 Versions
  • 32 % Grown

The README.md

Phing Copy Files Task

Copy files with better control over copying than the default Phing CopyTask., (*1)

The main disadvantage of the default task is that it ignores the overwrite="false" setting (which is also default) and if the source file is newer, it always rewrites the target file (see phingofficial/phing#538). This is unexpected and potentially very dangerous behaviour especially when copying configuration files etc., (*2)

CopyFilesTask has much narrower use-cases, but offers you more control about the copied files. It works only with files (not directories or filesets) and you can specify how exactly each of the files should be copied and what to do when the target already exists., (*3)

Usage

To copy a file you can just write:, (*4)

<target name="copy-configs">
    <copy-files>
        <file source="parameters.local.yml.dist" target="parameters.local.yml"/>
    </copy-files>
</target>

The paths are relative to the location of the buildfile. If you want to use absolute paths, you can write paths using ${project.basedir}, which contains the location of the buildfile., (*5)

You can also copy multiple files within one task definition:, (*6)

<target name="copy-configs">
    <copy-files>
        <file source="parameters.local.yml.dist" target="parameters.local.yml"/>
        <file source="${environment}/parameters.yml" target="parameters.yml"/>
    </copy-files>
</target>

Target file exists mode

If the target file already exists, there are three modes how you can choose that the situation will be handled:, (*7)

1) skip (default) - copying of the file is skipped (and logged to output) 2) replace - always replace target file, even if it exists 3) fail - do not overwrite the target file and fail the build, (*8)

You can set the mode for all files at once with existsmode parameter on <copy-files>:, (*9)

<target name="copy-configs">
    <copy-files existsmode="skip">
        <file source="parameters.local.yml.dist" target="parameters.local.yml"/>
        <file source="${environment}/parameters.yml" target="parameters.yml"/>
    </copy-files>
</target>

And also for each <file>, meaning it will override the <copy-files> setting:, (*10)

<target name="copy-configs">
    <copy-files existsmode="skip">
        <file source="parameters.local.yml.dist" target="parameters.local.yml"/>
        <file source="${environment}/parameters.yml" target="parameters.yml" existsmode="replace"/>
    </copy-files>
</target>

Installation

1) Install package vasek-purchart/phing-copy-files-task with Composer:, (*11)

composer require vasek-purchart/phing-copy-files-task

2) Register this task under a name of your choosing., (*12)

There are several ways how to register a task, see the TaskDefTask documentation. The recommended way is putting this in your build.xml:, (*13)

<taskdef name="copy-files" classname="VasekPurchart\Phing\CopyFiles\CopyFilesTask"/>

You can pick any other name for the command if you would like to., (*14)

The Versions

22/09 2017

dev-master

9999999-dev

Copy files with better control over copying than the default Phing CopyTask

  Sources   Download

MIT

The Requires

 

The Development Requires

file task copy phing

22/09 2017

dev-dev-dependencies

dev-dev-dependencies

Copy files with better control over copying than the default Phing CopyTask

  Sources   Download

MIT

The Requires

 

The Development Requires

file task copy phing

27/03 2017

1.0

1.0.0.0

Copy files with better control over copying than the default Phing CopyTask

  Sources   Download

MIT

The Requires

 

The Development Requires

file task copy phing