NAME

Git::Raw::Reference - Git reference class

VERSION

version 0.45

DESCRIPTION

A Git::Raw::Reference represents a Git reference.

WARNING: The API of this module is unstable and may change without warning (any change will be appropriately documented in the changelog).

METHODS

lookup( $name, $repo )

Retrieve the reference with name $name in $repo.

create( $name, $repo, $object [, $force] )

Creates and returns a new direct reference named $name in $repo pointing to $object. $object can be a Git::Raw::Blob, Git::Raw::Commit, or a Git::Raw::Tree object. If $force is a truthy value, any existing reference is overwritten. If $force is falsy (the default) and a reference named $name already exists, an error is thrown.

delete( )

Delete the reference. The Git::Raw::Reference object must not be accessed afterwards.

name( )

Retrieve the name of the reference.

shorthand( )

Get the reference's short name. This will transform the reference name into a "human-readable" version. If no shortname is appropriate, it will return the full name.

type( )

Retrieve the type of the reference. Can be either "direct" or "symbolic".

target( [$new_target] )

Retrieve the target of the reference. If the $new_target parameter of type Git::Raw::Reference is passed, the reference will be changed to point to it.

Note that updating the target will invalidate all existing handles to the reference.

This function returns either an object (Git::Raw::Blob, Git::Raw::Commit, Git::Raw::Tag or Git::Raw::Tree) for direct references, or another reference for symbolic references.

peel( $type )

Recursively peel the reference until an object of the specified $type is found. Valid values for $type include: "commit", "tree" or "tag".

reflog( )

Retrieve the Git::Raw::Reflog of the reference. Shortcut for Git::Raw::Reflog->open().

owner( )

Retrieve the Git::Raw::Repository owning the reference.

is_branch( )

Check if the reference is a branch.

is_remote( )

Check if the reference is remote.

is_tag( )

Check if the reference lives in the refs/tags namespace.

is_note( )

Check if the reference lives in the refs/notes namespace.

AUTHOR

Alessandro Ghedini <alexbio@cpan.org>

Jacques Germishuys <jacquesg@striata.com>

LICENSE AND COPYRIGHT

Copyright 2012 Alessandro Ghedini.

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.