NAME

Git::Database::Role::Object - Role for objects from the Git object database

VERSION

version 0.005

SYNOPSIS

package Git::Database::Object::Blob;

use Moo;

with 'Git::Database::Role::Object';

sub kind { 'blob' }

1;

DESCRIPTION

Git::Database::Role::Object provides the generic behaviour for all Git::Database objects obtained from or stored into the Git object database.

When creating a new object meant to be added to the Git object database (via backend), only the "content" attribute is actually required.

New objects are typically created via Git::Database::Role::ObjectReader's get_object method, rather than by calling new directly. This is when the object data is fetched from the Git object database.

ATTRIBUTES

The content, size and digest attribute are lazy, and can be computed from the others: size from content, content from digest (if the object exists in the backend store), and digest from content. All attributes have a predicate method.

Additional attributes in some classes may add other ways to compute the content.

Creating a new object with inconsistent kind, size, content and digest attributes can only end in tears. This is also true for additional attributes such as directory_entries, commit_info, and tag_info.

For now, as soon as the "content" of a Git::Database::Role::Object is needed, it is fully loaded in memory.

backend

A Git::Database::Role::Backend from which the object comes from (or will be stored into). It is typically used by the attribute builders.

If none is provided, a Git::Database::Backend::None is used, which is only able to compute the digest.

content

The object's actual content.

size

The size (in bytes) of the object content.

digest

The SHA-1 digest of the object, as computed by Git.

If set at creation time, it is internally converted to lowercase.

METHODS

as_string

Return a string representation of the content.

By default, this is the same as content(), but some classes may override it.

REQUIRED METHODS

kind

Returns the object "kind".

In Git, this is one of blob, tree, commit, and tag.

SEE ALSO

Git::Database::Object::Blob, Git::Database::Object::Tree, Git::Database::Object::Commit, Git::Database::Object::Tag.

AUTHOR

Philippe Bruhat (BooK) <book@cpan.org>.

COPYRIGHT

Copyright 2013-2016 Philippe Bruhat (BooK), all rights reserved.

LICENSE

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.