Subversion Repositories Applications.gtt

Rev

Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
/*
 * +------------------------------------------------------------------------+
 * | PEAR :: Package File Manager :: Perforce                               |
 * +------------------------------------------------------------------------+
 * | Copyright (c) 2004 Jon Parise                                          |
 * | Email         jon@php.net                                              |
 * +------------------------------------------------------------------------+
 * | This source file is subject to version 3.00 of the PHP License,        |
 * | that is available at http://www.php.net/license/3_0.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.                 |
 * +------------------------------------------------------------------------+
 * $Id: Perforce.php,v 1.2 2004/08/25 06:02:30 jon Exp $
 */

/**
 * @package PEAR_PackageFileManager
 */

/**
 * The PEAR_PackageFileManager_File class
 */
require_once 'PEAR/PackageFileManager/File.php';

/**
 * Generate a file list from a Perforce checkout.  This requires the 'p4'
 * command line client, a properly-configured Perforce environment, and a
 * connection to the Perforce server.  Specifically, the 'p4 have' command
 * is used to determine which local files are under Perforce's control.
 *
 * @author  Jon Parise <jon@php.net>
 * @package PEAR_PackageFileManager
 */
class PEAR_PackageFileManager_Perforce extends PEAR_PackageFileManager_File
{
    /**
     * Build a list of files based on the output of the 'p4 have' command.
     *
     * @param   string  $directory  The directory in which to list the files.
     *
     * @return  mixed   An array of full filenames or a PEAR_Error value if
     *                  $directory does not exist.
     */
    function dirList($directory)
    {
        /* Return an error if the directory does not exist. */
        if (@is_dir($directory) === false) {
            return PEAR_PackageFileManager::raiseError(
                            PEAR_PACKAGEFILEMANAGER_DIR_DOESNT_EXIST,
                            $directory);
        }

        /* List the files below $directory that are under Perforce control. */
        exec("p4 have $directory/...", $output);

        /* Strip off everything except the filename from each line of output. */
        $files = preg_replace('/^.* \- /', '', $output);

        /* If we have a list of files to include, remove all other entries. */
        if ($this->ignore[0]) {
            $files = array_filter($files, array($this, '_includeFilter'));
        }

        /* If we have a list of files to ignore, remove them from the array. */
        if ($this->ignore[1]) {
            $files = array_filter($files, array($this, '_ignoreFilter'));
        }

        return $files;
    }

    /**
     * Determine whether a given file should be excluded from the file list.
     * 
     * @param   string  $file       The full pathname of file to check.
     * 
     * @return  bool    True if the specified file should be included.
     *
     * @access  private
     */
    function _includeFilter($file)
    {
        return ($this->_checkIgnore(basename($file), $file, 0) === 0);
    }

    /**
     * Determine whether a given file should be included (i.e., not ignored)
     * from the file list.
     * 
     * @param   string  $file       The full pathname of file to check.
     * 
     * @return  bool    True if the specified file should be included.
     *
     * @access  private
     */
    function _ignoreFilter($file)
    {
        return ($this->_checkIgnore(basename($file), $file, 1) !== 1);
    }
}