use MooseX::Declare;
use Moose::Autobox;
-class Gitalist::Git::Object {
+class Gitalist::Git::Object with Gitalist::Git::Serializable is dirty {
+ use MooseX::Storage::Meta::Attribute::Trait::DoNotSerialize;
+
use MooseX::Types::Moose qw/Str Int Bool Maybe ArrayRef/;
use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
- use File::Stat::ModeString qw/mode_to_string/;
+ use Gitalist::Utils qw/mode_string/;
+ use overload '""' => '_to_string', fallback => 1;
- # project and sha1 are required initargs
- has project => ( isa => 'Gitalist::Git::Project',
+ # repository and sha1 are required initargs
+ has repository => ( isa => 'Gitalist::Git::Repository',
required => 1,
is => 'ro',
weak_ref => 1,
lazy_build => 1 )
for qw/modestr size/;
- has _gpp_obj => ( isa => 'Git::PurePerl::Object',
- required => 1,
- is => 'ro',
+ has _gpp_obj => ( isa => 'Git::PurePerl::Object',
+ required => 1,
+ is => 'ro',
lazy_build => 1,
- handles => [ 'content',
- ],
+ handles => [ 'content' ],
+ traits => ['DoNotSerialize']
);
# objects can't determine their mode or filename
method BUILD { $self->$_() for qw/_gpp_obj size modestr/ }
## Private methods
+ method _to_string {
+ return $self->sha1;
+ };
## Builders
method _build__gpp_obj {
return $v;
}
- method _build_modestr {
- my $modestr = mode_to_string($self->mode);
- return $modestr;
- }
-
method _cat_file_with_flag ($flag) {
$self->_run_cmd('cat-file', '-' . $flag, $self->{sha1})
}
+ method _build_modestr {
+ return mode_string($self->mode);
+ }
+
} # end class
+
+__END__
+
+=head1 NAME
+
+Gitalist::Git::Object - Model of a git object.
+
+=head1 SYNOPSIS
+
+ my $object = Repository->get_object($sha1);
+
+=head1 DESCRIPTION
+
+Abstract base class for git objects.
+
+
+=head1 ATTRIBUTES
+
+
+=head1 METHODS
+
+
+=head1 AUTHORS
+
+See L<Gitalist> for authors.
+
+=head1 LICENSE
+
+See L<Gitalist> for the license.
+
+=cut