libminifi/include/io/validation.h (43 lines of code) (raw):

/** * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #pragma once #include <type_traits> #include <string> #include <memory> #include "utils/meta/detected.h" namespace org::apache::nifi::minifi { namespace detail { template<typename T> concept emptiness_checkable = requires(T t) { // NOLINT { t.empty() }; // NOLINT }; // NOLINT template<typename T> concept size_checkable = requires(T t) { // NOLINT { t.size() }; // NOLINT }; // NOLINT template<typename T> concept only_size_checkable = !emptiness_checkable<T> && size_checkable<T>; template<typename T> concept not_size_or_emptiness_checkable = !emptiness_checkable<T> && !size_checkable<T>; } // namespace detail /** * Determines if the variable is null or ::empty() */ static bool IsNullOrEmpty(detail::emptiness_checkable auto& object) { return object.empty(); } /** * Determines if the variable is null or ::empty() */ static bool IsNullOrEmpty(detail::emptiness_checkable auto* object) { return (nullptr == object || object->empty()); } /** * Determines if the variable is null or ::size() == 0 */ static bool IsNullOrEmpty(detail::only_size_checkable auto* object) { return (nullptr == object || object->size() == 0); } /** * Determines if the variable is null */ static bool IsNullOrEmpty(detail::not_size_or_emptiness_checkable auto* object) { return (nullptr == object); } /** * Determines if the variable is null or ::empty() */ template<typename T> requires (!detail::emptiness_checkable<T>) // NOLINT static bool IsNullOrEmpty(std::shared_ptr<T> object) { return (nullptr == object || nullptr == object.get()); } template<detail::only_size_checkable T> static bool IsNullOrEmpty(std::shared_ptr<T> object) { return (nullptr == object || nullptr == object.get() || object->size() == 0); } } // namespace org::apache::nifi::minifi // TODO(szaszm): clean up this file using org::apache::nifi::minifi::IsNullOrEmpty;