NAME

Chemistry::File

SYNOPSIS

# As a convenient interface for several mol readers:
use Chemistry::Mol;
use Chemistry::File qw(PDB MDLMol); # load PDB and MDL modules

# or try to use every file I/O module installed in the system:
use Chemistry::File ':auto';

my $mol1 = Chemistry::Mol->read("file.pdb");
my $mol2 = Chemistry::Mol->read("file.mol");

# as a base for a mol reader:

package Chemistry::File::Myfile;
use base Chemistry::File;
Chemistry::Mol->register_type("myfile", __PACKAGE__);
# override the parse_string method
sub parse_string {
    my ($self, $string, %opts) = shift;
    my $mol_class = $opts{mol_class} || "Chemistry::Mol";
    my $mol = $mol_class->new;
    # ... do some stuff with $string and $mol ...
    return $mol;
}

DESCRIPTION

The main use of this module is as a base class for other molecule file I/O modules (for example, Chemistry::File::PDB). Such modules should extend the Chemistry::File methods as needed. You only need to care about them if you are writing a file I/O module.

From the user's point of view, this module can also be used as shorthand for using several Chemistry::File modules at the same time.

use Chemistry::File qw(PDB MDLMol);

is exactly equivalent to

use Chemistry::File::PDB;
use Chemistry::File::MDLMol;

If you use the :auto keyword, Chemistry::File can try to autodetect and load all the Chemistry::File::* modules installed in your system.

use Chemistry::File ':auto';

This basically looks for files of the name File/*.pm under the directory where Chemistry::File is installed.

STANDARD OPTIONS

All the methods below include a list of options %options at the end of the parameter list. Each class implementing this interface may have its own particular options. However, the following options should be implemented by all classes:

mol_class

A class or object with a new method that constructs a molecule. This is needed when the user want to specify a molecule subclass different from the default. When this option is not present, the Chemistry::Mol class may be used as a default.

atom_class

Same as above, for atoms.

bond_class

Same as above, for bonds.

format

The file format being used, as registered by Chemistry::Mol->register_format.

METHODS

The methods in this class (or rather, its derived classes) are usually not called directly. Instead, use Chemistry::Mol->read , write, print, and parse.

$class->parse_string($s, %options)

Parse a string $s and return one or mole molecule objects. This is an abstract method, so it should be provided by all derived classes.

$class->write_string($mol, %options)

Convert a molecule to a string. This is an abstract method, so it should be provided by all derived classes.

$class->parse_file($fname, %options)

Reads the file $fname and returns one or more molecules. The default method slurps the whole file and then calls parse_string, but derived classes may choose to override it.

$class->write_file($mol, $fname, %options)

Writes a file $fname containing the molecule $mol. The default method calls write_string first and then saves the string to a file, but derived classes may choose to override it.

$class->name_is($fname, %options)

Returns true if a filename is of the format corresponding to the class. It should look at the filename only, because it may be called with non-existent files. It is used to determine with which format to save a file. For example, the Chemistry::File::PDB returns true if the file ends in .pdb.

$class->string_is($s, %options)

Examines the string $s and returns true if it has the format of the class.

$class->file_is($fname, %options)

Examines the file $fname and returns true if it has the format of the class. The default method slurps the whole file and then calls string_is, but derived classes may choose to override it.

CAVEATS

The :auto feature only looks in one directory. If you have modules in several different directories, it will only find those that are installed next to Chemistry::File itself.

VERSION

0.20

SEE ALSO

Chemistry::Mol

The PerlMol website http://www.perlmol.org/

AUTHOR

Ivan Tubert-Brohman <itub@cpan.org>

COPYRIGHT

Copyright (c) 2004 Ivan Tubert. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.