Max Kanat-Alexander > VCI-0.5.1 > VCI::Abstract::Diff

Download:
VCI-0.5.1.tar.gz

Dependencies

Annotate this POD

Website

CPAN RT

Open  0
View/Report Bugs
Source   Latest Release: VCI-0.7.1

NAME ^

VCI::Abstract::Diff - An object representing a "diff" or "patch" from a Version-Control System

SYNOPSIS ^

 my $diff = $commit->as_diff;

 my $file_changes = $diff->files;
 foreach my $file (@$files) {
     my $changes = $file->changes;
     my $path    = $file->path;
 }

 my $text = $diff->raw;

DESCRIPTION ^

Every VCS can generate a patch in "diff" format that can be applied to re-create the changes in a particular commit.

This class represents the actual changes made to each file in a commit, and can also be represented in "diff" format.

METHODS ^

Accessors

All accessors are read-only.

files

An arrayref of VCI::Abstract::Diff::File objects, which each represent the changes made to that particular file.

Files that were added but have no contents aren't tracked in the Diff.

Note that changes to binary files aren't tracked.

raw

The exact text of the diff, as it would be returned by the version-control system. If will be in unified diff format, but other details of the format of the patch may be specific to the VCS.

project

The VCI::Abstract::Project that this Diff is from.

For Subclass Implementors

If you are just a user of VCI::Abstract::Diff, you don't need to read about these.

_transform_filename

To make implementing this class easier, you can override this function to transform the filenames that appear in the patch into filenames relative to the root of your Project.

CLASS METHODS ^

Constructor

Usually you won't construct an instance of this class directly, but instead, use "as_diff" in VCI::Abstract::Commit.

new

Takes all "Accessors" as named parameters. The following fields are required: "raw", and "project".

syntax highlighting: