Skip to content

Commit

Permalink
Remove the use of YGUnwrapOptional from YGConstrainedMaxSizeForMode
Browse files Browse the repository at this point in the history
Reviewed By: emilsjolander

Differential Revision: D7322743

fbshipit-source-id: d825c60bcdc9ecdc0c784a215dc6b1b8a7a7860e
  • Loading branch information
priteshrnandgaonkar authored and facebook-github-bot committed Apr 4, 2018
1 parent 2ace555 commit dbb2c6b
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 9 deletions.
19 changes: 17 additions & 2 deletions ReactCommon/yoga/yoga/YGFloatOptional.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,16 @@
#include <iostream>
#include "Yoga.h"

YGFloatOptional::YGFloatOptional(const float& value)
: value_(value), isUndefined_(false) {}
YGFloatOptional::YGFloatOptional(const float& value) {
if (YGFloatIsUndefined(value)) {
isUndefined_ = true;
value_ = 0;
} else {
value_ = value;
isUndefined_ = false;
}
}

YGFloatOptional::YGFloatOptional() : value_(0), isUndefined_(true) {}

const float& YGFloatOptional::getValue() const {
Expand Down Expand Up @@ -53,3 +61,10 @@ bool YGFloatOptional::operator==(const float& val) const {
bool YGFloatOptional::operator!=(const float& val) const {
return !(*this == val);
}

YGFloatOptional YGFloatOptional::operator+(const YGFloatOptional& op) {
if (!isUndefined_ && !op.isUndefined_) {
return YGFloatOptional(value_ + op.value_);
}
return YGFloatOptional();
}
1 change: 1 addition & 0 deletions ReactCommon/yoga/yoga/YGFloatOptional.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ struct YGFloatOptional {

const bool& isUndefined() const;

YGFloatOptional operator+(const YGFloatOptional& op);
bool operator==(const YGFloatOptional& op) const;
bool operator!=(const YGFloatOptional& op) const;

Expand Down
1 change: 1 addition & 0 deletions ReactCommon/yoga/yoga/YGNode.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -167,6 +167,7 @@ float YGNode::getTrailingMargin(
widthSize));
}

// TODO: Make its return type to YGFloatOptional
float YGNode::getMarginForAxis(
const YGFlexDirection axis,
const float widthSize) const {
Expand Down
16 changes: 9 additions & 7 deletions ReactCommon/yoga/yoga/Yoga.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1178,19 +1178,21 @@ static void YGConstrainMaxSizeForMode(const YGNodeRef node,
const float ownerWidth,
YGMeasureMode *mode,
float *size) {
const float maxSize =
YGUnwrapFloatOptional(YGResolveValue(
node->getStyle().maxDimensions[dim[axis]], ownerAxisSize)) +
node->getMarginForAxis(axis, ownerWidth);
const YGFloatOptional maxSize =
YGResolveValue(
node->getStyle().maxDimensions[dim[axis]], ownerAxisSize) +
YGFloatOptional(node->getMarginForAxis(axis, ownerWidth));
switch (*mode) {
case YGMeasureModeExactly:
case YGMeasureModeAtMost:
*size = (YGFloatIsUndefined(maxSize) || *size < maxSize) ? *size : maxSize;
*size = (maxSize.isUndefined() || *size < maxSize.getValue())
? *size
: maxSize.getValue();
break;
case YGMeasureModeUndefined:
if (!YGFloatIsUndefined(maxSize)) {
if (!maxSize.isUndefined()) {
*mode = YGMeasureModeAtMost;
*size = maxSize;
*size = maxSize.getValue();
}
break;
}
Expand Down

0 comments on commit dbb2c6b

Please sign in to comment.