Вход Регистрация
Файл: sys/inc/libs/MP3/IDv2/Frame/POPM.php
Строк: 187
<?php
/**
 * This file contains the implementation for POPM frame
 *
 * PHP version 5
 * 
 * Copyright (C) 2006-2007 Alexander Merz
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 *
 * @category  File_Formats
 * @package   MP3_IDv2
 * @author    Alexander Merz <alexander.merz@web.de>
 * @copyright 2006-2007 Alexander Merz
 * @license   http://www.gnu.org/licenses/lgpl.html LGPL 2.1
 * @version   CVS: $Id: POPM.php 248530 2007-12-18 21:36:37Z alexmerz $
 * @link      http://pear.php.net/package/MP3_IDv2
 * @since     File available since Release 0.1
 */

/**
 * load parent class
 */
require_once 'MP3/IDv2/Frame.php';

/**
 * Data stucture for POPM frame in a tag.
 * (Popularimeter)
 *
 * The implementation is an optimistic one,
 * it expects, that the counter doesn't become
 * larger then 32 bit.
 *
 * @category File_Formats
 * @package  MP3_IDv2
 * @author   Alexander Merz <alexander.merz@web.de>
 * @license  http://www.gnu.org/licenses/lgpl.html LGPL 2.1
 * @version  Release: @package_version@
 * @link     http://pear.php.net/package/MP3_IDv2
 * @since    Class available since Release 0.1.0
 */
class MP3_IDv2_Frame_POPM extends MP3_IDv2_Frame
{

    
/**
     * the rating
     * @var int
     */
    
public $_rating 0;

    
/**
     * email address
     * @var string
     */
    
private $_email "";

    
/**
     * the counter
     * @var int
     */
    
private $_counter "";

    
/**
     * Sets the counter.
     * 
     * @param int $c counter value
     * 
     * @return void
     * @access public
     */
    
public function setCounter($c
    {
        
$this->_changed true;
        
$this->_counter $c;
    }

    
/**
     * Returns the counter.
     * 
     * @return int the counter value
     * @access public
     */
    
public function getCounter() 
    {
        return 
$this->_counter;
    }

    
/**
     * Sets the rating.
     * Must between 0 (worst) and 255 (best).
     * 
     * @param int $c rating value
     * 
     * @return void
     * @access public
     */
    
public function setRating($c
    {
        
$this->_changed true;
        if (
$c 0) {
            
$c 0;
        } else if (
$c 255) {
            
$c 255;
        }
        
$this->_rating $c;
    }

    
/**
     * Returns the rating.
     * 
     * @return int the rating value
     * @access public
     */
    
public function getRating() 
    {
        return 
$this->_rating;
    }

    
/**
     * Sets the email address.
     * 
     * @param string $email the email adsress
     * 
     * @return void
     * @access public
     */
    
public function setEmail($email
    {
        
$this->_changed true;
        if (
"" == substr($email, -1)) {
            
$email substr($email0, -1);
        }
        
$this->_email $email;
    }

    
/**
     * Returns the email address.
     *
     * @param bool $nul if true appends a null
     * 
     * @return string the email address
     * @access public
     */
    
public function getEmail($nul false
    {
        
$ret $this->_email;
        if (
$nul) {
            if (
"" != substr($ret, -1)) {
                
$ret $ret."";
            }
        }
        return 
$ret;
    }

    
/**
     * Creates the content of the frame (encoding+language+tou)
     * 
     * @return string the frame content
     * @access public
     */
    
public function createContent() 
    {
        return 
$this->getEmail(true).
                
pack("C"$this->getRating()).
                
pack("N"$this->getCounter());
    }

    
/**
     * Sets the data of the frame and processes it.
     * 
     * @param string $content the unproccess content for the frame
     * 
     * @return void
     * @access public
     */
    
public function setRawContent($content
    {
        
$this->_changed true;
        
$this->_content $content;
        
        
$c explode(""$content);
        
        
$this->setEmail($c[0]);
        
$this->setRating(substr($c[1], 01));
        
        if (
<= strlen($c[1])) {
            
$this->setCounter(substr($c[1], 1));
        }
    }

    
/**
     * Sets the id and the purpose of the frame
     * 
     * @return void
     * @access public
     */
    
function __construct() 
    {
        
$this->_id      "POPM";
        
$this->_purpose "Popularimeter";
    }

    
/**
     * Returns the frame content as something printable
     *
     * @return string the frame content
     * @access public
     */
    
public function toString() 
    {
        return 
$this->getID()." (".$this->getPurpose().") ".
                
$this->getEmail()." ".$this->getRating()." ".
                
$this->getCounter();
    }

}
?>
Онлайн: 1
Реклама