// clang-format off // This file is generated. Edit scripts/generate-style-code.js, then run `make style-code`. #include #include #include #include #include #include #include #include #include #include #include namespace mbgl { namespace style { // static const LayerTypeInfo* CircleLayer::Impl::staticTypeInfo() noexcept { const static LayerTypeInfo typeInfo{"circle", LayerTypeInfo::Source::Required, LayerTypeInfo::Pass3D::NotRequired, LayerTypeInfo::Layout::NotRequired, LayerTypeInfo::FadingTiles::NotRequired, LayerTypeInfo::CrossTileIndex::NotRequired, LayerTypeInfo::TileKind::Geometry}; return &typeInfo; } CircleLayer::CircleLayer(const std::string& layerID, const std::string& sourceID) : Layer(makeMutable(layerID, sourceID)) { } CircleLayer::CircleLayer(Immutable impl_) : Layer(std::move(impl_)) { } CircleLayer::~CircleLayer() = default; const CircleLayer::Impl& CircleLayer::impl() const { return static_cast(*baseImpl); } Mutable CircleLayer::mutableImpl() const { return makeMutable(impl()); } std::unique_ptr CircleLayer::cloneRef(const std::string& id_) const { auto impl_ = mutableImpl(); impl_->id = id_; impl_->paint = CirclePaintProperties::Transitionable(); return std::make_unique(std::move(impl_)); } void CircleLayer::Impl::stringifyLayout(rapidjson::Writer&) const { } // Layout properties // Paint properties PropertyValue CircleLayer::getDefaultCircleBlur() { return { 0 }; } const PropertyValue& CircleLayer::getCircleBlur() const { return impl().paint.template get().value; } void CircleLayer::setCircleBlur(const PropertyValue& value) { if (value == getCircleBlur()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleBlurTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleBlurTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCircleColor() { return { Color::black() }; } const PropertyValue& CircleLayer::getCircleColor() const { return impl().paint.template get().value; } void CircleLayer::setCircleColor(const PropertyValue& value) { if (value == getCircleColor()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleColorTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleColorTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCircleOpacity() { return { 1 }; } const PropertyValue& CircleLayer::getCircleOpacity() const { return impl().paint.template get().value; } void CircleLayer::setCircleOpacity(const PropertyValue& value) { if (value == getCircleOpacity()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleOpacityTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleOpacityTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCirclePitchAlignment() { return { AlignmentType::Viewport }; } const PropertyValue& CircleLayer::getCirclePitchAlignment() const { return impl().paint.template get().value; } void CircleLayer::setCirclePitchAlignment(const PropertyValue& value) { if (value == getCirclePitchAlignment()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCirclePitchAlignmentTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCirclePitchAlignmentTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCirclePitchScale() { return { CirclePitchScaleType::Map }; } const PropertyValue& CircleLayer::getCirclePitchScale() const { return impl().paint.template get().value; } void CircleLayer::setCirclePitchScale(const PropertyValue& value) { if (value == getCirclePitchScale()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCirclePitchScaleTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCirclePitchScaleTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCircleRadius() { return { 5 }; } const PropertyValue& CircleLayer::getCircleRadius() const { return impl().paint.template get().value; } void CircleLayer::setCircleRadius(const PropertyValue& value) { if (value == getCircleRadius()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleRadiusTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleRadiusTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCircleStrokeColor() { return { Color::black() }; } const PropertyValue& CircleLayer::getCircleStrokeColor() const { return impl().paint.template get().value; } void CircleLayer::setCircleStrokeColor(const PropertyValue& value) { if (value == getCircleStrokeColor()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleStrokeColorTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleStrokeColorTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCircleStrokeOpacity() { return { 1 }; } const PropertyValue& CircleLayer::getCircleStrokeOpacity() const { return impl().paint.template get().value; } void CircleLayer::setCircleStrokeOpacity(const PropertyValue& value) { if (value == getCircleStrokeOpacity()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleStrokeOpacityTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleStrokeOpacityTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCircleStrokeWidth() { return { 0 }; } const PropertyValue& CircleLayer::getCircleStrokeWidth() const { return impl().paint.template get().value; } void CircleLayer::setCircleStrokeWidth(const PropertyValue& value) { if (value == getCircleStrokeWidth()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleStrokeWidthTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleStrokeWidthTransition() const { return impl().paint.template get().options; } PropertyValue> CircleLayer::getDefaultCircleTranslate() { return { {{ 0, 0 }} }; } const PropertyValue>& CircleLayer::getCircleTranslate() const { return impl().paint.template get().value; } void CircleLayer::setCircleTranslate(const PropertyValue>& value) { if (value == getCircleTranslate()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleTranslateTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleTranslateTransition() const { return impl().paint.template get().options; } PropertyValue CircleLayer::getDefaultCircleTranslateAnchor() { return { TranslateAnchorType::Map }; } const PropertyValue& CircleLayer::getCircleTranslateAnchor() const { return impl().paint.template get().value; } void CircleLayer::setCircleTranslateAnchor(const PropertyValue& value) { if (value == getCircleTranslateAnchor()) return; auto impl_ = mutableImpl(); impl_->paint.template get().value = value; baseImpl = std::move(impl_); observer->onLayerChanged(*this); } void CircleLayer::setCircleTranslateAnchorTransition(const TransitionOptions& options) { auto impl_ = mutableImpl(); impl_->paint.template get().options = options; baseImpl = std::move(impl_); } TransitionOptions CircleLayer::getCircleTranslateAnchorTransition() const { return impl().paint.template get().options; } using namespace conversion; namespace { enum class Property { CircleBlur, CircleColor, CircleOpacity, CirclePitchAlignment, CirclePitchScale, CircleRadius, CircleStrokeColor, CircleStrokeOpacity, CircleStrokeWidth, CircleTranslate, CircleTranslateAnchor, CircleBlurTransition, CircleColorTransition, CircleOpacityTransition, CirclePitchAlignmentTransition, CirclePitchScaleTransition, CircleRadiusTransition, CircleStrokeColorTransition, CircleStrokeOpacityTransition, CircleStrokeWidthTransition, CircleTranslateTransition, CircleTranslateAnchorTransition, }; MAPBOX_ETERNAL_CONSTEXPR const auto paintProperties = mapbox::eternal::hash_map( {{"circle-blur", mbgl::underlying_type(Property::CircleBlur)}, {"circle-color", mbgl::underlying_type(Property::CircleColor)}, {"circle-opacity", mbgl::underlying_type(Property::CircleOpacity)}, {"circle-pitch-alignment", mbgl::underlying_type(Property::CirclePitchAlignment)}, {"circle-pitch-scale", mbgl::underlying_type(Property::CirclePitchScale)}, {"circle-radius", mbgl::underlying_type(Property::CircleRadius)}, {"circle-stroke-color", mbgl::underlying_type(Property::CircleStrokeColor)}, {"circle-stroke-opacity", mbgl::underlying_type(Property::CircleStrokeOpacity)}, {"circle-stroke-width", mbgl::underlying_type(Property::CircleStrokeWidth)}, {"circle-translate", mbgl::underlying_type(Property::CircleTranslate)}, {"circle-translate-anchor", mbgl::underlying_type(Property::CircleTranslateAnchor)}, {"circle-blur-transition", mbgl::underlying_type(Property::CircleBlurTransition)}, {"circle-color-transition", mbgl::underlying_type(Property::CircleColorTransition)}, {"circle-opacity-transition", mbgl::underlying_type(Property::CircleOpacityTransition)}, {"circle-pitch-alignment-transition", mbgl::underlying_type(Property::CirclePitchAlignmentTransition)}, {"circle-pitch-scale-transition", mbgl::underlying_type(Property::CirclePitchScaleTransition)}, {"circle-radius-transition", mbgl::underlying_type(Property::CircleRadiusTransition)}, {"circle-stroke-color-transition", mbgl::underlying_type(Property::CircleStrokeColorTransition)}, {"circle-stroke-opacity-transition", mbgl::underlying_type(Property::CircleStrokeOpacityTransition)}, {"circle-stroke-width-transition", mbgl::underlying_type(Property::CircleStrokeWidthTransition)}, {"circle-translate-transition", mbgl::underlying_type(Property::CircleTranslateTransition)}, {"circle-translate-anchor-transition", mbgl::underlying_type(Property::CircleTranslateAnchorTransition)}}); } // namespace optional CircleLayer::setPaintProperty(const std::string& name, const Convertible& value) { const auto it = paintProperties.find(name.c_str()); if (it == paintProperties.end()) { return Error { "layer doesn't support this property" }; } auto property = static_cast(it->second); if (property == Property::CircleBlur || property == Property::CircleOpacity || property == Property::CircleRadius || property == Property::CircleStrokeOpacity || property == Property::CircleStrokeWidth) { Error error; optional> typedValue = convert>(value, error, true, false); if (!typedValue) { return error; } if (property == Property::CircleBlur) { setCircleBlur(*typedValue); return nullopt; } if (property == Property::CircleOpacity) { setCircleOpacity(*typedValue); return nullopt; } if (property == Property::CircleRadius) { setCircleRadius(*typedValue); return nullopt; } if (property == Property::CircleStrokeOpacity) { setCircleStrokeOpacity(*typedValue); return nullopt; } if (property == Property::CircleStrokeWidth) { setCircleStrokeWidth(*typedValue); return nullopt; } } if (property == Property::CircleColor || property == Property::CircleStrokeColor) { Error error; optional> typedValue = convert>(value, error, true, false); if (!typedValue) { return error; } if (property == Property::CircleColor) { setCircleColor(*typedValue); return nullopt; } if (property == Property::CircleStrokeColor) { setCircleStrokeColor(*typedValue); return nullopt; } } if (property == Property::CirclePitchAlignment) { Error error; optional> typedValue = convert>(value, error, false, false); if (!typedValue) { return error; } setCirclePitchAlignment(*typedValue); return nullopt; } if (property == Property::CirclePitchScale) { Error error; optional> typedValue = convert>(value, error, false, false); if (!typedValue) { return error; } setCirclePitchScale(*typedValue); return nullopt; } if (property == Property::CircleTranslate) { Error error; optional>> typedValue = convert>>(value, error, false, false); if (!typedValue) { return error; } setCircleTranslate(*typedValue); return nullopt; } if (property == Property::CircleTranslateAnchor) { Error error; optional> typedValue = convert>(value, error, false, false); if (!typedValue) { return error; } setCircleTranslateAnchor(*typedValue); return nullopt; } Error error; optional transition = convert(value, error); if (!transition) { return error; } if (property == Property::CircleBlurTransition) { setCircleBlurTransition(*transition); return nullopt; } if (property == Property::CircleColorTransition) { setCircleColorTransition(*transition); return nullopt; } if (property == Property::CircleOpacityTransition) { setCircleOpacityTransition(*transition); return nullopt; } if (property == Property::CirclePitchAlignmentTransition) { setCirclePitchAlignmentTransition(*transition); return nullopt; } if (property == Property::CirclePitchScaleTransition) { setCirclePitchScaleTransition(*transition); return nullopt; } if (property == Property::CircleRadiusTransition) { setCircleRadiusTransition(*transition); return nullopt; } if (property == Property::CircleStrokeColorTransition) { setCircleStrokeColorTransition(*transition); return nullopt; } if (property == Property::CircleStrokeOpacityTransition) { setCircleStrokeOpacityTransition(*transition); return nullopt; } if (property == Property::CircleStrokeWidthTransition) { setCircleStrokeWidthTransition(*transition); return nullopt; } if (property == Property::CircleTranslateTransition) { setCircleTranslateTransition(*transition); return nullopt; } if (property == Property::CircleTranslateAnchorTransition) { setCircleTranslateAnchorTransition(*transition); return nullopt; } return Error { "layer doesn't support this property" }; } LayerProperty CircleLayer::getPaintProperty(const std::string& name) const { const auto it = paintProperties.find(name.c_str()); if (it == paintProperties.end()) { return {}; } switch (static_cast(it->second)) { case Property::CircleBlur: return conversion::makeLayerProperty(getCircleBlur()); case Property::CircleColor: return conversion::makeLayerProperty(getCircleColor()); case Property::CircleOpacity: return conversion::makeLayerProperty(getCircleOpacity()); case Property::CirclePitchAlignment: return conversion::makeLayerProperty(getCirclePitchAlignment()); case Property::CirclePitchScale: return conversion::makeLayerProperty(getCirclePitchScale()); case Property::CircleRadius: return conversion::makeLayerProperty(getCircleRadius()); case Property::CircleStrokeColor: return conversion::makeLayerProperty(getCircleStrokeColor()); case Property::CircleStrokeOpacity: return conversion::makeLayerProperty(getCircleStrokeOpacity()); case Property::CircleStrokeWidth: return conversion::makeLayerProperty(getCircleStrokeWidth()); case Property::CircleTranslate: return conversion::makeLayerProperty(getCircleTranslate()); case Property::CircleTranslateAnchor: return conversion::makeLayerProperty(getCircleTranslateAnchor()); case Property::CircleBlurTransition: return conversion::makeLayerProperty(getCircleBlurTransition()); case Property::CircleColorTransition: return conversion::makeLayerProperty(getCircleColorTransition()); case Property::CircleOpacityTransition: return conversion::makeLayerProperty(getCircleOpacityTransition()); case Property::CirclePitchAlignmentTransition: return conversion::makeLayerProperty(getCirclePitchAlignmentTransition()); case Property::CirclePitchScaleTransition: return conversion::makeLayerProperty(getCirclePitchScaleTransition()); case Property::CircleRadiusTransition: return conversion::makeLayerProperty(getCircleRadiusTransition()); case Property::CircleStrokeColorTransition: return conversion::makeLayerProperty(getCircleStrokeColorTransition()); case Property::CircleStrokeOpacityTransition: return conversion::makeLayerProperty(getCircleStrokeOpacityTransition()); case Property::CircleStrokeWidthTransition: return conversion::makeLayerProperty(getCircleStrokeWidthTransition()); case Property::CircleTranslateTransition: return conversion::makeLayerProperty(getCircleTranslateTransition()); case Property::CircleTranslateAnchorTransition: return conversion::makeLayerProperty(getCircleTranslateAnchorTransition()); } return {}; } optional CircleLayer::setLayoutProperty(const std::string& name, const Convertible& value) { if (name == "visibility") { return Layer::setVisibility(value); } return Error { "layer doesn't support this property" }; } Mutable CircleLayer::mutableBaseImpl() const { return staticMutableCast(mutableImpl()); } } // namespace style } // namespace mbgl // clang-format on