############################################################################### # # Package: NaturalDocs::ImageReferenceTable::String # ############################################################################### # # A package for creating and managing . # ############################################################################### # This file is part of Natural Docs, which is Copyright © 2003-2010 Greg Valure # Natural Docs is licensed under version 3 of the GNU Affero General Public License (AGPL) # Refer to License.txt for the complete details use strict; use integer; package NaturalDocs::ImageReferenceTable::String; # # Type: ImageReferenceString # # A string representing a unique image reference. It's composed of the reference text and the directory of the source file. # The source file name itself isn't included because two files in the same directory with the same reference text will always go # to the same targets. # # # Function: Make # # Converts a source and the reference text to an . # sub Make #(FileName sourceFile, string text) => ImageReferenceString { my ($self, $sourceFile, $text) = @_; my $path = NaturalDocs::File->NoFileName($sourceFile); # Condense whitespace and remove any separator characters. $path =~ tr/ \t\r\n\x1C/ /s; $text =~ tr/ \t\r\n\x1C/ /s; return $path . "\x1C" . $text; }; # # Function: InformationOf # # Returns the information contained in the as the array ( path, text ). # sub InformationOf #(ImageReferenceString referenceString) { my ($self, $referenceString) = @_; return split(/\x1C/, $referenceString); }; # # Function: ToBinaryFile # # Writes an to . Can also encode an undef. # # Format: # # > [UString16: path] [UString16: reference text] ... # # Undef is represented by the first UString16 being undef. # sub ToBinaryFile #(ImageReferenceString referenceString) { my ($self, $referenceString) = @_; if (defined $referenceString) { my ($path, $text) = split(/\x1C/, $referenceString); NaturalDocs::BinaryFile->WriteUString16($path); NaturalDocs::BinaryFile->WriteUString16($text); } else { NaturalDocs::BinaryFile->WriteUString16(undef); }; }; # # Function: FromBinaryFile # # Loads an or undef from and returns it. # sub FromBinaryFile { my $self = shift; my $path = NaturalDocs::BinaryFile->GetUString16(); if (!defined $path) { return undef; }; my $text = NaturalDocs::BinaryFile->GetUString16(); return $path . "\x1C" . $text; }; 1;