google.protobuf.MethodDescriptorProto
 */
class MethodDescriptorProto extends \Google\Protobuf\Internal\Message
{
    /**
     * Generated from protobuf field optional string name = 1;
     */
    protected $name = null;
    /**
     * Input and output type names.  These are resolved in the same way as
     * FieldDescriptorProto.type_name, but must refer to a message type.
     *
     * Generated from protobuf field optional string input_type = 2;
     */
    protected $input_type = null;
    /**
     * Generated from protobuf field optional string output_type = 3;
     */
    protected $output_type = null;
    /**
     * Generated from protobuf field optional .google.protobuf.MethodOptions options = 4;
     */
    protected $options = null;
    /**
     * Identifies if client streams multiple client messages
     *
     * Generated from protobuf field optional bool client_streaming = 5 [default = false];
     */
    protected $client_streaming = null;
    /**
     * Identifies if server streams multiple server messages
     *
     * Generated from protobuf field optional bool server_streaming = 6 [default = false];
     */
    protected $server_streaming = null;
    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type string $name
     *     @type string $input_type
     *           Input and output type names.  These are resolved in the same way as
     *           FieldDescriptorProto.type_name, but must refer to a message type.
     *     @type string $output_type
     *     @type \Google\Protobuf\Internal\MethodOptions $options
     *     @type bool $client_streaming
     *           Identifies if client streams multiple client messages
     *     @type bool $server_streaming
     *           Identifies if server streams multiple server messages
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Google\Protobuf\Internal\Descriptor::initOnce();
        parent::__construct($data);
    }
    /**
     * Generated from protobuf field optional string name = 1;
     * @return string
     */
    public function getName()
    {
        return isset($this->name) ? $this->name : '';
    }
    public function hasName()
    {
        return isset($this->name);
    }
    public function clearName()
    {
        unset($this->name);
    }
    /**
     * Generated from protobuf field optional string name = 1;
     * @param string $var
     * @return $this
     */
    public function setName($var)
    {
        GPBUtil::checkString($var, True);
        $this->name = $var;
        return $this;
    }
    /**
     * Input and output type names.  These are resolved in the same way as
     * FieldDescriptorProto.type_name, but must refer to a message type.
     *
     * Generated from protobuf field optional string input_type = 2;
     * @return string
     */
    public function getInputType()
    {
        return isset($this->input_type) ? $this->input_type : '';
    }
    public function hasInputType()
    {
        return isset($this->input_type);
    }
    public function clearInputType()
    {
        unset($this->input_type);
    }
    /**
     * Input and output type names.  These are resolved in the same way as
     * FieldDescriptorProto.type_name, but must refer to a message type.
     *
     * Generated from protobuf field optional string input_type = 2;
     * @param string $var
     * @return $this
     */
    public function setInputType($var)
    {
        GPBUtil::checkString($var, True);
        $this->input_type = $var;
        return $this;
    }
    /**
     * Generated from protobuf field optional string output_type = 3;
     * @return string
     */
    public function getOutputType()
    {
        return isset($this->output_type) ? $this->output_type : '';
    }
    public function hasOutputType()
    {
        return isset($this->output_type);
    }
    public function clearOutputType()
    {
        unset($this->output_type);
    }
    /**
     * Generated from protobuf field optional string output_type = 3;
     * @param string $var
     * @return $this
     */
    public function setOutputType($var)
    {
        GPBUtil::checkString($var, True);
        $this->output_type = $var;
        return $this;
    }
    /**
     * Generated from protobuf field optional .google.protobuf.MethodOptions options = 4;
     * @return \Google\Protobuf\Internal\MethodOptions|null
     */
    public function getOptions()
    {
        return $this->options;
    }
    public function hasOptions()
    {
        return isset($this->options);
    }
    public function clearOptions()
    {
        unset($this->options);
    }
    /**
     * Generated from protobuf field optional .google.protobuf.MethodOptions options = 4;
     * @param \Google\Protobuf\Internal\MethodOptions $var
     * @return $this
     */
    public function setOptions($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Internal\MethodOptions::class);
        $this->options = $var;
        return $this;
    }
    /**
     * Identifies if client streams multiple client messages
     *
     * Generated from protobuf field optional bool client_streaming = 5 [default = false];
     * @return bool
     */
    public function getClientStreaming()
    {
        return isset($this->client_streaming) ? $this->client_streaming : false;
    }
    public function hasClientStreaming()
    {
        return isset($this->client_streaming);
    }
    public function clearClientStreaming()
    {
        unset($this->client_streaming);
    }
    /**
     * Identifies if client streams multiple client messages
     *
     * Generated from protobuf field optional bool client_streaming = 5 [default = false];
     * @param bool $var
     * @return $this
     */
    public function setClientStreaming($var)
    {
        GPBUtil::checkBool($var);
        $this->client_streaming = $var;
        return $this;
    }
    /**
     * Identifies if server streams multiple server messages
     *
     * Generated from protobuf field optional bool server_streaming = 6 [default = false];
     * @return bool
     */
    public function getServerStreaming()
    {
        return isset($this->server_streaming) ? $this->server_streaming : false;
    }
    public function hasServerStreaming()
    {
        return isset($this->server_streaming);
    }
    public function clearServerStreaming()
    {
        unset($this->server_streaming);
    }
    /**
     * Identifies if server streams multiple server messages
     *
     * Generated from protobuf field optional bool server_streaming = 6 [default = false];
     * @param bool $var
     * @return $this
     */
    public function setServerStreaming($var)
    {
        GPBUtil::checkBool($var);
        $this->server_streaming = $var;
        return $this;
    }
}