����

Example #1 Yar Serverʾ��

<?php

/* �������ҳ��ķ���·����: http://example.com/operator.php */

class Operator {

    
/**
     * Add two operands
     * @param interge 
     * @return interge
     */
    
public function add($a$b) {
        return 
$this->_add($a$b);
    }

    
/**
     * Sub 
     */
    
public function sub($a$b) {
        return 
$a $b;
    }

    
/**
     * Mul
     */
    
public function mul($a$b) {
        return 
$a $b;
    }

    
/**
     * Protected methods will not be exposed
     * @param interge 
     * @return interge
     */
    
protected function _add($a$b) {
        return 
$a $b;
    }
}

$server = new Yar_Server(new Operator());
$server->handle();
?>

Example #2 ͨ�����������(GET����)

�������̵���������ڣ�

Yar Server Info

Example #3 Yar Clientʾ��

<?php
$client 
= new yar_client("http://example.com/operator.php");

/* call directly */
var_dump($client->add(12));

/* call via call */
var_dump($client->call("add", array(32)));


/* __add can not be called */
var_dump($client->_add(12));
?>

�������̵���������ڣ�

int(3)
int(5)
PHP Fatal error:  Uncaught exception 'Yar_Server_Exception' with message 'call to api Operator::_add() failed' in *

Example #4 Yar Concurrent Clientʾ��

<?php
function callback($ret$callinfo) {
    echo 
$callinfo['method'] , " result: "$ret "\n";
}

/* ע��һ���첽���� */
Yar_Concurrent_Client::call("http://example.com/operator.php""add", array(12), "callback");
Yar_Concurrent_Client::call("http://example.com/operator.php""sub", array(21), "callback");
Yar_Concurrent_Client::call("http://example.com/operator.php""mul", array(22), "callback");

/* ��������ע��ĵ���, �ȴ�����, ���غ�Yar�����callback�ص����� */
Yar_Concurrent_Client::loop();
?>

�������̵���������ڣ�

mul result: 4
sub result: 1
add result: 3