Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x

FieldDescriptor.php

Same filename in this branch
  1. 11.1.x vendor/google/protobuf/src/Google/Protobuf/Internal/FieldDescriptor.php

Namespace

Google\Protobuf

File

vendor/google/protobuf/src/Google/Protobuf/FieldDescriptor.php

View source
<?php

// Protocol Buffers - Google's data interchange format
// Copyright 2017 Google Inc.  All rights reserved.
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file or at
// https://developers.google.com/open-source/licenses/bsd
namespace Google\Protobuf;

use Google\Protobuf\Internal\GetPublicDescriptorTrait;
use Google\Protobuf\Internal\GPBType;
class FieldDescriptor {
    use GetPublicDescriptorTrait;
    
    /** @var  \Google\Protobuf\Internal\FieldDescriptor $internal_desc */
    private $internal_desc;
    
    /**
     * @internal
     */
    public function __construct($internal_desc) {
        $this->internal_desc = $internal_desc;
    }
    
    /**
     * @return string Field name
     */
    public function getName() {
        return $this->internal_desc
            ->getName();
    }
    
    /**
     * @return int Protobuf field number
     */
    public function getNumber() {
        return $this->internal_desc
            ->getNumber();
    }
    
    /**
     * @return int
     */
    public function getLabel() {
        return $this->internal_desc
            ->getLabel();
    }
    
    /**
     * @return int
     */
    public function getType() {
        return $this->internal_desc
            ->getType();
    }
    
    /**
     * @return OneofDescriptor
     */
    public function getContainingOneof() {
        return $this->getPublicDescriptor($this->internal_desc
            ->getContainingOneof());
    }
    
    /**
     * Gets the field's containing oneof, only if non-synthetic.
     *
     * @return null|OneofDescriptor
     */
    public function getRealContainingOneof() {
        return $this->getPublicDescriptor($this->internal_desc
            ->getRealContainingOneof());
    }
    
    /**
     * @return boolean
     */
    public function hasOptionalKeyword() {
        return $this->internal_desc
            ->hasOptionalKeyword();
    }
    
    /**
     * @return Descriptor Returns a descriptor for the field type if the field type is a message, otherwise throws \Exception
     * @throws \Exception
     */
    public function getMessageType() {
        if ($this->getType() == GPBType::MESSAGE) {
            return $this->getPublicDescriptor($this->internal_desc
                ->getMessageType());
        }
        else {
            throw new \Exception("Cannot get message type for non-message field '" . $this->getName() . "'");
        }
    }
    
    /**
     * @return EnumDescriptor Returns an enum descriptor if the field type is an enum, otherwise throws \Exception
     * @throws \Exception
     */
    public function getEnumType() {
        if ($this->getType() == GPBType::ENUM) {
            return $this->getPublicDescriptor($this->internal_desc
                ->getEnumType());
        }
        else {
            throw new \Exception("Cannot get enum type for non-enum field '" . $this->getName() . "'");
        }
    }
    
    /**
     * @return boolean
     */
    public function isMap() {
        return $this->internal_desc
            ->isMap();
    }

}

Classes

Title Deprecated Summary
FieldDescriptor

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal