checkpoint, not sure what is here
[scpubgit/stemmatology.git] / lib / Text / Tradition / Witness.pm
1 package Text::Tradition::Witness;
2 use Moose;
3 use Moose::Util::TypeConstraints;
4
5 # Sigil. Required identifier for a witness.
6 has 'sigil' => (
7     is => 'ro',
8     isa => 'Str',
9     required => 1,
10     );
11
12 # Text.  This is an array of strings (i.e. word tokens).
13 # TODO Think about how to handle this for the case of pre-prepared
14 # collations, where the tokens are in the graph already.
15 has 'text' => (
16     is => 'rw',
17     isa => 'ArrayRef[Str]',
18     predicate => 'has_text',
19     );
20
21 # Source.  This is where we read in the witness, if not from a
22 # pre-prepared collation.  It is probably a filename.
23 has 'source' => (
24     is => 'ro',
25     isa => 'Str',
26     predicate => 'has_source',
27     );
28
29 # Path.  This is an array of Reading nodes that should mirror the
30 # text above.
31 has 'path' => (
32     is => 'rw',
33     isa => 'ArrayRef[Text::Tradition::Collation::Reading]',
34     predicate => 'has_path',
35     );         
36
37 has 'uncorrected_path' => (
38     is => 'rw',
39     isa => 'ArrayRef[Text::Tradition::Collation::Reading]',
40     predicate => 'has_ante_corr',
41     );
42
43 # Manuscript name or similar
44 has 'identifier' => (
45     is => 'ro',
46     isa => 'Str',
47     );
48
49 # Any other info we have
50 has 'other_info' => (
51     is => 'ro',
52     isa => 'Str',
53     );
54     
55
56 sub BUILD {
57     my $self = shift;
58     if( $self->has_source ) {
59         # Read the file and initialize the text.
60         open( WITNESS, $self->source ) or die "Could not open " 
61             . $self->file . "for reading";
62         # TODO support TEI as well as plaintext, sometime
63         my @words;
64         while(<WITNESS>) {
65             chomp;
66             push( @words, split( /\s+/, $_ ) );
67         }
68         close WITNESS;
69         $self->text( \@words );
70     }
71 }
72
73 # If the text is not present, and the path is, and this is a 'get'
74 # request, generate text from path.
75 around text => sub {
76     my $orig = shift;
77     my $self = shift;
78
79     if( $self->has_path && !$self->has_text && !@_ ) {
80         my @words = map { $_->label } @{$self->path};
81         $self->$orig( \@words );
82     }
83     
84     $self->$orig( @_ );
85 };
86
87 no Moose;
88 __PACKAGE__->meta->make_immutable;