Skip to content

Commit

Permalink
Fixes bugs of isSynthetic and makes containing_oneof work
Browse files Browse the repository at this point in the history
  • Loading branch information
fiboknacky committed Jun 3, 2022
1 parent 238331b commit 594f2a9
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 20 deletions.
8 changes: 0 additions & 8 deletions php/src/Google/Protobuf/FieldDescriptor.php
Original file line number Diff line number Diff line change
Expand Up @@ -82,14 +82,6 @@ public function getType()
return $this->internal_desc->getType();
}

/**
* @return int
*/
public function getOneofIndex()
{
return $this->internal_desc->getOneofIndex();
}

/**
* @return OneofDescriptor
*/
Expand Down
9 changes: 5 additions & 4 deletions php/src/Google/Protobuf/Internal/Descriptor.php
Original file line number Diff line number Diff line change
Expand Up @@ -193,10 +193,6 @@ public static function buildFromProto($proto, $file_proto, $containing)
$desc->setLegacyClass($legacy_classname);
$desc->setOptions($proto->getOptions());

foreach ($proto->getField() as $field_proto) {
$desc->addField(FieldDescriptor::buildFromProto($field_proto, $desc));
}

// Handle nested types.
foreach ($proto->getNestedType() as $nested_proto) {
$desc->addNestedType(Descriptor::buildFromProto(
Expand All @@ -217,6 +213,11 @@ public static function buildFromProto($proto, $file_proto, $containing)
$index++;
}

// Pass the descriptor to build FieldDescriptor after the OneofDescriptors are populated.
foreach ($proto->getField() as $field_proto) {
$desc->addField(FieldDescriptor::buildFromProto($field_proto, $desc));
}

return $desc;
}
}
11 changes: 4 additions & 7 deletions php/src/Google/Protobuf/Internal/FieldDescriptor.php
Original file line number Diff line number Diff line change
Expand Up @@ -49,8 +49,6 @@ class FieldDescriptor
private $oneof_index = -1;
private $proto3_optional;

/** @var Descriptor $containing_type */
private $containing_type;
/** @var OneofDescriptor $containing_oneof */
private $containing_oneof;

Expand Down Expand Up @@ -242,10 +240,10 @@ private static function isTypePackable($field_type)

/**
* @param FieldDescriptorProto $proto
* @param Descriptor $parent_desc
* @param Descriptor $desc
* @return FieldDescriptor
*/
public static function getFieldDescriptor($proto, $parent_desc)
public static function getFieldDescriptor($proto, $desc)
{
$type_name = null;
$type = $proto->getType();
Expand All @@ -261,10 +259,10 @@ public static function getFieldDescriptor($proto, $parent_desc)

if ($proto->hasOneofIndex()) {
$oneof_index = $proto->getOneofIndex();
$containing_oneof = $parent_desc->getOneofDecl()[$oneof_index];
$containing_oneof = $desc->getOneofDecl()[$oneof_index];
} else {
$containing_oneof = null;
$oneof_index = -1;
$containing_oneof = null;
}
// TODO: once proto2 is supported, this default should be false
// for proto2.
Expand All @@ -284,7 +282,6 @@ public static function getFieldDescriptor($proto, $parent_desc)

$field = new FieldDescriptor();
$field->setName($proto->getName());
$field->containing_type = $parent_desc;
$field->containing_oneof = $containing_oneof;

$json_name = $proto->hasJsonName() ? $proto->getJsonName() :
Expand Down
3 changes: 2 additions & 1 deletion php/src/Google/Protobuf/Internal/OneofDescriptor.php
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,8 @@ public function getFields()

public function isSynthetic()
{
return count($this->fields) === 1 && $this->fields[0]->getProto3Optional();
return !is_null($this->fields) && count($this->fields) === 1
&& $this->fields[0]->getProto3Optional();
}

public static function buildFromProto($oneof_proto, $desc, $index)
Expand Down

0 comments on commit 594f2a9

Please sign in to comment.