// Copyright 2019 The MediaPipe Authors. // // Licensed 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. #ifndef MEDIAPIPE_FRAMEWORK_CALCULATOR_CONTRACT_H_ #define MEDIAPIPE_FRAMEWORK_CALCULATOR_CONTRACT_H_ #include <map> #include <memory> #include <string> #include <typeindex> // TODO: Move protos in another CL after the C++ code migration. #include "absl/container/flat_hash_map.h" #include "absl/strings/string_view.h" #include "mediapipe/framework/calculator.pb.h" #include "mediapipe/framework/graph_service.h" #include "mediapipe/framework/mediapipe_options.pb.h" #include "mediapipe/framework/packet_generator.pb.h" #include "mediapipe/framework/packet_type.h" #include "mediapipe/framework/port.h" #include "mediapipe/framework/port/any_proto.h" #include "mediapipe/framework/status_handler.pb.h" #include "mediapipe/framework/tool/options_map.h" namespace mediapipe { // CalculatorContract contains the expectations and properties of a Node // object, such as the expected packet types of input and output streams and // input and output side packets. // // Setters and getters are available for specifying an InputStreamHandler and // it's options from inside a calculator's GetContract() method. Ex: // cc->SetInputStreamHandler("FixedSizeInputStreamHandler"); // MediaPipeOptions options; // options.MutableExtension(FixedSizeInputStreamHandlerOptions::ext) // ->set_fixed_min_size(2); // cc->SetInputStreamHandlerOptions(options); // class CalculatorContract { … }; } // namespace mediapipe #endif // MEDIAPIPE_FRAMEWORK_CALCULATOR_CONTRACT_H_