PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/react-native/ReactCommon/react/renderer/css

Просмотр файла: CSSShadow.h

/*
 * Copyright (c) Meta Platforms, Inc. and affiliates.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 */

#pragma once

#include <optional>
#include <tuple>

#include <react/renderer/css/CSSColor.h>
#include <react/renderer/css/CSSDataType.h>
#include <react/renderer/css/CSSKeyword.h>
#include <react/renderer/css/CSSLength.h>
#include <react/renderer/css/CSSList.h>
#include <react/renderer/css/CSSValueParser.h>
#include <react/utils/to_underlying.h>

namespace facebook::react {

/**
 * Representation of CSS <shadow> data type
 * https://drafts.csswg.org/css-backgrounds/#typedef-shadow
 */
struct CSSShadow {
  CSSLength offsetX{};
  CSSLength offsetY{};
  CSSLength blurRadius{};
  CSSLength spreadDistance{};
  CSSColor color{CSSColor::black()};
  bool inset{false};

  constexpr bool operator==(const CSSShadow& rhs) const = default;
};

/**
 * Represents a keyword for an inset shadow.
 */
enum class CSSInsetShadowKeyword : std::underlying_type_t<CSSKeyword> {
  Inset = to_underlying(CSSKeyword::Inset),
};

static_assert(CSSDataType<CSSInsetShadowKeyword>);

template <>
struct CSSDataTypeParser<CSSShadow> {
  static constexpr auto consume(CSSSyntaxParser& parser)
      -> std::optional<CSSShadow> {
    std::optional<CSSColor> color{};
    bool inset{false};
    std::optional<std::tuple<CSSLength, CSSLength, CSSLength, CSSLength>>
        lengths{};

    for (auto nextValue =
             parseNextCSSValue<CSSLength, CSSColor, CSSInsetShadowKeyword>(
                 parser);
         !std::holds_alternative<std::monostate>(nextValue);
         nextValue =
             parseNextCSSValue<CSSLength, CSSColor, CSSInsetShadowKeyword>(
                 parser, CSSDelimiter::Whitespace)) {
      if (std::holds_alternative<CSSLength>(nextValue)) {
        if (lengths.has_value()) {
          return {};
        }
        lengths = parseRestLengths(std::get<CSSLength>(nextValue), parser);
        if (!lengths.has_value()) {
          return {};
        }
        continue;
      }

      if (std::holds_alternative<CSSColor>(nextValue)) {
        if (color.has_value()) {
          return {};
        }
        color = std::get<CSSColor>(nextValue);
        continue;
      }

      if (std::holds_alternative<CSSInsetShadowKeyword>(nextValue)) {
        if (inset) {
          return {};
        }
        inset = true;
        continue;
      }
    }

    if (!lengths.has_value()) {
      return {};
    }

    return CSSShadow{
        .offsetX = std::get<0>(*lengths),
        .offsetY = std::get<1>(*lengths),
        .blurRadius = std::get<2>(*lengths),
        .spreadDistance = std::get<3>(*lengths),
        .color = color.value_or(CSSColor::black()),
        .inset = inset,
    };
  }

 private:
  static constexpr auto parseRestLengths(
      CSSLength offsetX,
      CSSSyntaxParser& parser)
      -> std::optional<std::tuple<CSSLength, CSSLength, CSSLength, CSSLength>> {
    auto offsetY =
        parseNextCSSValue<CSSLength>(parser, CSSDelimiter::Whitespace);
    if (std::holds_alternative<std::monostate>(offsetY)) {
      return {};
    }

    auto blurRadius =
        parseNextCSSValue<CSSLength>(parser, CSSDelimiter::Whitespace);
    if (std::holds_alternative<std::monostate>(blurRadius)) {
      return std::make_tuple(
          offsetX, std::get<CSSLength>(offsetY), CSSLength{}, CSSLength{});
    }
    if (std::get<CSSLength>(blurRadius).value < 0) {
      return {};
    }

    auto spreadDistance =
        parseNextCSSValue<CSSLength>(parser, CSSDelimiter::Whitespace);
    if (std::holds_alternative<std::monostate>(spreadDistance)) {
      return std::make_tuple(
          offsetX,
          std::get<CSSLength>(offsetY),
          std::get<CSSLength>(blurRadius),
          CSSLength{});
    }

    return std::make_tuple(
        offsetX,
        std::get<CSSLength>(offsetY),
        std::get<CSSLength>(blurRadius),
        std::get<CSSLength>(spreadDistance));
  }
};

static_assert(CSSDataType<CSSShadow>);

/**
 * Represents a comma separated list of at least one <shadow>
 * <shadow>#
 */
using CSSShadowList = CSSCommaSeparatedList<CSSShadow>;

} // namespace facebook::react

Выполнить команду


Для локальной разработки. Не используйте в интернете!