1ffe3c632Sopenharmony_ci<?php
2ffe3c632Sopenharmony_ci
3ffe3c632Sopenharmony_ci// Protocol Buffers - Google's data interchange format
4ffe3c632Sopenharmony_ci// Copyright 2017 Google Inc.  All rights reserved.
5ffe3c632Sopenharmony_ci// https://developers.google.com/protocol-buffers/
6ffe3c632Sopenharmony_ci//
7ffe3c632Sopenharmony_ci// Redistribution and use in source and binary forms, with or without
8ffe3c632Sopenharmony_ci// modification, are permitted provided that the following conditions are
9ffe3c632Sopenharmony_ci// met:
10ffe3c632Sopenharmony_ci//
11ffe3c632Sopenharmony_ci//     * Redistributions of source code must retain the above copyright
12ffe3c632Sopenharmony_ci// notice, this list of conditions and the following disclaimer.
13ffe3c632Sopenharmony_ci//     * Redistributions in binary form must reproduce the above
14ffe3c632Sopenharmony_ci// copyright notice, this list of conditions and the following disclaimer
15ffe3c632Sopenharmony_ci// in the documentation and/or other materials provided with the
16ffe3c632Sopenharmony_ci// distribution.
17ffe3c632Sopenharmony_ci//     * Neither the name of Google Inc. nor the names of its
18ffe3c632Sopenharmony_ci// contributors may be used to endorse or promote products derived from
19ffe3c632Sopenharmony_ci// this software without specific prior written permission.
20ffe3c632Sopenharmony_ci//
21ffe3c632Sopenharmony_ci// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22ffe3c632Sopenharmony_ci// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23ffe3c632Sopenharmony_ci// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24ffe3c632Sopenharmony_ci// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25ffe3c632Sopenharmony_ci// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26ffe3c632Sopenharmony_ci// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27ffe3c632Sopenharmony_ci// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28ffe3c632Sopenharmony_ci// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29ffe3c632Sopenharmony_ci// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30ffe3c632Sopenharmony_ci// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31ffe3c632Sopenharmony_ci// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32ffe3c632Sopenharmony_ci
33ffe3c632Sopenharmony_cinamespace Google\Protobuf;
34ffe3c632Sopenharmony_ci
35ffe3c632Sopenharmony_ciuse Google\Protobuf\Internal\GetPublicDescriptorTrait;
36ffe3c632Sopenharmony_ciuse Google\Protobuf\Internal\GPBType;
37ffe3c632Sopenharmony_ci
38ffe3c632Sopenharmony_ciclass FieldDescriptor
39ffe3c632Sopenharmony_ci{
40ffe3c632Sopenharmony_ci    use GetPublicDescriptorTrait;
41ffe3c632Sopenharmony_ci
42ffe3c632Sopenharmony_ci    private $internal_desc;
43ffe3c632Sopenharmony_ci
44ffe3c632Sopenharmony_ci    /**
45ffe3c632Sopenharmony_ci     * @internal
46ffe3c632Sopenharmony_ci     */
47ffe3c632Sopenharmony_ci    public function __construct($internal_desc)
48ffe3c632Sopenharmony_ci    {
49ffe3c632Sopenharmony_ci        $this->internal_desc = $internal_desc;
50ffe3c632Sopenharmony_ci    }
51ffe3c632Sopenharmony_ci
52ffe3c632Sopenharmony_ci    /**
53ffe3c632Sopenharmony_ci     * @return string Field name
54ffe3c632Sopenharmony_ci     */
55ffe3c632Sopenharmony_ci    public function getName()
56ffe3c632Sopenharmony_ci    {
57ffe3c632Sopenharmony_ci        return $this->internal_desc->getName();
58ffe3c632Sopenharmony_ci    }
59ffe3c632Sopenharmony_ci
60ffe3c632Sopenharmony_ci    /**
61ffe3c632Sopenharmony_ci     * @return int Protobuf field number
62ffe3c632Sopenharmony_ci     */
63ffe3c632Sopenharmony_ci    public function getNumber()
64ffe3c632Sopenharmony_ci    {
65ffe3c632Sopenharmony_ci        return $this->internal_desc->getNumber();
66ffe3c632Sopenharmony_ci    }
67ffe3c632Sopenharmony_ci
68ffe3c632Sopenharmony_ci    /**
69ffe3c632Sopenharmony_ci     * @return int
70ffe3c632Sopenharmony_ci     */
71ffe3c632Sopenharmony_ci    public function getLabel()
72ffe3c632Sopenharmony_ci    {
73ffe3c632Sopenharmony_ci        return $this->internal_desc->getLabel();
74ffe3c632Sopenharmony_ci    }
75ffe3c632Sopenharmony_ci
76ffe3c632Sopenharmony_ci    /**
77ffe3c632Sopenharmony_ci     * @return int
78ffe3c632Sopenharmony_ci     */
79ffe3c632Sopenharmony_ci    public function getType()
80ffe3c632Sopenharmony_ci    {
81ffe3c632Sopenharmony_ci        return $this->internal_desc->getType();
82ffe3c632Sopenharmony_ci    }
83ffe3c632Sopenharmony_ci
84ffe3c632Sopenharmony_ci    /**
85ffe3c632Sopenharmony_ci     * @return Descriptor Returns a descriptor for the field type if the field type is a message, otherwise throws \Exception
86ffe3c632Sopenharmony_ci     * @throws \Exception
87ffe3c632Sopenharmony_ci     */
88ffe3c632Sopenharmony_ci    public function getMessageType()
89ffe3c632Sopenharmony_ci    {
90ffe3c632Sopenharmony_ci        if ($this->getType() == GPBType::MESSAGE) {
91ffe3c632Sopenharmony_ci            return $this->getPublicDescriptor($this->internal_desc->getMessageType());
92ffe3c632Sopenharmony_ci        } else {
93ffe3c632Sopenharmony_ci            throw new \Exception("Cannot get message type for non-message field '" . $this->getName() . "'");
94ffe3c632Sopenharmony_ci        }
95ffe3c632Sopenharmony_ci    }
96ffe3c632Sopenharmony_ci
97ffe3c632Sopenharmony_ci    /**
98ffe3c632Sopenharmony_ci     * @return EnumDescriptor Returns an enum descriptor if the field type is an enum, otherwise throws \Exception
99ffe3c632Sopenharmony_ci     * @throws \Exception
100ffe3c632Sopenharmony_ci     */
101ffe3c632Sopenharmony_ci    public function getEnumType()
102ffe3c632Sopenharmony_ci    {
103ffe3c632Sopenharmony_ci        if ($this->getType() == GPBType::ENUM) {
104ffe3c632Sopenharmony_ci            return $this->getPublicDescriptor($this->internal_desc->getEnumType());
105ffe3c632Sopenharmony_ci        } else {
106ffe3c632Sopenharmony_ci            throw new \Exception("Cannot get enum type for non-enum field '" . $this->getName() . "'");
107ffe3c632Sopenharmony_ci        }
108ffe3c632Sopenharmony_ci    }
109ffe3c632Sopenharmony_ci
110ffe3c632Sopenharmony_ci    /**
111ffe3c632Sopenharmony_ci     * @return boolean
112ffe3c632Sopenharmony_ci     */
113ffe3c632Sopenharmony_ci    public function isMap()
114ffe3c632Sopenharmony_ci    {
115ffe3c632Sopenharmony_ci        return $this->internal_desc->isMap();
116ffe3c632Sopenharmony_ci    }
117ffe3c632Sopenharmony_ci
118ffe3c632Sopenharmony_ci    /**
119ffe3c632Sopenharmony_ci     * @return boolean
120ffe3c632Sopenharmony_ci     */
121ffe3c632Sopenharmony_ci    public function hasOptionalKeyword()
122ffe3c632Sopenharmony_ci    {
123ffe3c632Sopenharmony_ci        return $this->internal_desc->hasOptionalKeyword();
124ffe3c632Sopenharmony_ci    }
125ffe3c632Sopenharmony_ci}
126