/*
 * Copyright (c) Huawei Technologies Co., Ltd. 2025. All rights reserved.
 * You can use this software according to the terms and conditions of the Mulan PSL v2.
 * You may obtain a copy of Mulan PSL v2 at:
 *          http://license.coscl.org.cn/MulanPSL2
 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
 * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
 * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
 * See the Mulan PSL v2 for more details.
 */

#ifndef FLINK_TNEL_ABSTRACTTWOINPUTSTREAMOPERATOR_H
#define FLINK_TNEL_ABSTRACTTWOINPUTSTREAMOPERATOR_H

#include "StreamOperator.h"
#include "streaming/runtime/streamrecord/StreamRecord.h"
#include "core/include/common.h"


class TwoInputStreamOperator : public  StreamOperator {
public:
    ~TwoInputStreamOperator() override = default;

    virtual void processBatch1(StreamRecord* element)
    {
        THROW_LOGIC_EXCEPTION("To be implemented");
    }

    virtual void processBatch2(StreamRecord* element)
    {
        THROW_LOGIC_EXCEPTION("To be implemented");
    }

    virtual void processElement1(StreamRecord* element)
    {
        THROW_LOGIC_EXCEPTION("To be implemented");
    }

    virtual void processElement2(StreamRecord* element)
    {
        THROW_LOGIC_EXCEPTION("To be implemented");
    }
    virtual void ProcessWatermark1(Watermark* watermark)
    {
        THROW_LOGIC_EXCEPTION("To be implemented");
    }
    virtual void ProcessWatermark2(Watermark* watermark)
    {
        THROW_LOGIC_EXCEPTION("To be implemented");
    }
    void initializeState(StreamTaskStateInitializerImpl *initializer, TypeSerializer *keySerializer) override
    {
        THROW_LOGIC_EXCEPTION("To be implemented");
    }

    std::string getTypeName() override
    {
        return "TwoInputStreamOperator";
    }
};
#endif