Current File : //opt/RZphp74/includes/Science/Chemistry/PDBFile.php
<?php
//
// +----------------------------------------------------------------------+
// | PHP Version 4                                                        |
// +----------------------------------------------------------------------+
// | Copyright (c) 1997-2003 The PHP Group                                |
// +----------------------------------------------------------------------+
// | This source file is subject to version 2.0 of the PHP license,       |
// | that is bundled with this package in the file LICENSE, and is        |
// | available at through the world-wide-web at                           |
// | http://www.php.net/license/2_02.txt.                                 |
// | If you did not receive a copy of the PHP license and are unable to   |
// | obtain it through the world-wide-web, please send a note to          |
// | license@php.net so we can mail you a copy immediately.               |
// +----------------------------------------------------------------------+
// | Authors: Jesus M. Castagnetto <jmcastagnetto@php.net>                |
// +----------------------------------------------------------------------+
//
// $Id$
//

require_once "Science/Chemistry/Macromolecule_PDB.php";

/**
 * Represents a PDB file, composed of one or more Science_Chemistry_Macromolecule_PDB objects
 *
 * @author  Jesus M. Castagnetto <jmcastagnetto@php.net>
 * @version 1.0
 * @access  public
 * @package Science_Chemistry
 * @see     Science_Chemistry_PDBParser
 */
class Science_Chemistry_PDBFile {

    /**
     * PDB ID
     *
     * @var     string
     * @access   private
     */
    var $pdb;

    /**
     * Full path to PDB file
     *
     * @var     string
     * @access  private
     */
    var $file;

    /**
     * PDB file's date
     *
     * @var     string
     * @access  private
     */
    var $date;

    /**
     * PDB macromolecule(s) class
     *
     * @var     string
     * @access  private
     */
    var $class;

    /**
     * Array of meta records
     *
     * @var     array
     * @access  private
     */
    var $meta;

    /**
     * Array of macromolecular objects
     *
     * @var     array
     * @access  private
     */
    var $macromolecules;

    /**
     * Number of molecules/subunits
     *
     * @var     int
     * @access  private
     */
    var $num_macromolecules;

    /**
     * Constructor for the class, requires a PDB filename
     * 
     * @param   string  $filename
     * @return  object  PDBFile;
     * @access  public
     * @see     $pdb
     * @see     $file
     * @see     mkArrays()
     */
    function Science_Chemistry_PDBFile($filename, $usemeta=false) {
        if (!file_exists($filename))
            return null;
        list($pdb,) = explode(".",basename($filename));
        $this->pdb = $pdb;
        $this->file = realpath($filename);
        $this->parseFile(file($filename), $usemeta);
    }

    /**
     * Makes the arrays of all present PDB record types
     *
     * @param   array   $arr    array of lines
     * @access  private
     * @see     Science_Chemistry_Macromolecule_PDB()
     */
	function parseFile($arr, $usemeta) {
        $month = array (
                "JAN" => "01", "FEB" => "02", "MAR" => "03",
                "APR" => "04", "MAY" => "05", "JUN" => "06",
                "JUL" => "07", "AUG" => "08", "SEP" => "09",
                "OCT" => "10", "NOV" => "11", "DEC" => "12"
                );
        $header_re = "/^HEADER[[:space:]]+(([^[:space:]]+ )+)[[:space:]]+";
        $header_re .= "([0-9]{2}-[A-Z]{3}-[0-9]{2,4})[[:space:]]+[A-Z0-9]{4}/";

        if (preg_match($header_re, $arr[0], $regs)) {
            $this->class = trim($regs[1]);
            // put date in a more standard format
            $tmp = explode("-", $regs[3]);
            if ($tmp[2] <= 23)
                $year = 2000 + (int)$tmp[2];
            else
                $year = 1900 + (int)$tmp[2];
            $this->date = $year."-".$month[$tmp[1]]."-".$tmp[0];
        }
        
        $flag = "nomodel";
        $tmparr = array();
        for ($i=0; $i < count($arr); $i++) {
			if (!trim($arr[$i]))
                continue;
			$rectype = trim(strtok($arr[$i]," "));
            
            // check if we have multi-model file
            if ($rectype == "MODEL") {
                $flag = "model";
                continue;
            }

            // create the meta array and accumulate the atom records
            if ($rectype != "ATOM" && $rectype != "HETATM") {
                if ($usemeta) {
                    $this->meta[$rectype][] = trim($arr[$i]);
                } else {
                    continue;
                }
            } else {
                $tmparr[] = $arr[$i];
            }

            // did we get a multi-model file and are parsing the end
            // of a model, if so, create new macromolecule and change
            // the flag
            if ($rectype == "ENDMDL") {
                $this->macromolecules[] = new Science_Chemistry_Macromolecule_PDB($this->pdb, 
                                                $tmparr, $this);
                $this->num_macromolecules++;
                $flag = "endmodel";
                $tmparr = array();
            }
		}
        // if we got to the end without hitting a MODEL ... ENDMDL pair
        // add the only macromolecule in this file to the array
        if ($flag == "nomodel") {
            $this->macromolecules[] = new Science_Chemistry_Macromolecule_PDB($this->pdb, 
                                            $tmparr, $this);
            $this->num_macromolecules++;
        }
	}

    /**
     * Returns a CML representation of the PDB file
     * TODO
     *
     * @return  string
     * @access  public
     */
    function toCML() {
        // TODO
    }
    
} // end of PDBFile

// vim: expandtab: ts=4: sw=4
?>