/**
 * Copyright (c) 2025 Huawei Technologies Co., Ltd.
 * This program is free software, you can redistribute it and/or modify it under the terms and conditions of 
 * CANN Open Software License Agreement Version 2.0 (the "License").
 * Please refer to the License for details. You may not use this file except in compliance with the License.
 * 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 FITNESS FOR A PARTICULAR PURPOSE.
 * See LICENSE in the root of the software repository for the full text of the License.
 */

#ifndef GE_GRAPH_PASSES_PARTITIONED_CALL_OP_LABEL_PASS_H_
#define GE_GRAPH_PASSES_PARTITIONED_CALL_OP_LABEL_PASS_H_

#include "graph/node.h"
#include "graph/label/label_maker.h"
/*******************************************************************************
                                                            +---------------+
                                                            |     Node      |
                                                            +---------------+
                                                            |     Node      |
                                                            +---------------+
                                                            |PartitionedCall|
                                                            +---------------+
    +---------------+
    |     Node      |                                       +---------------+
    +---------------+                                       | StreamActive  |
    |     Node      |                                       +---------------+
    +---------------+                                       |       f       |
    |     Node      |                                       +---------------+
    +---------------+                                       |       u       |
    |PartitionedCall|                                       +---------------+
    +---------------+                                       |       n       |
    |     Node      |                      ====>            +---------------+
    +---------------+                                       |       c       |
    |     Node      |                                       +---------------+
    +---------------+
    |     Node      |                                       +---------------+
    +---------------+                                       |     Node      |
                                                            +---------------+
                                                            |     Node      |
        +---------------+                                   +---------------+
        |       f       |                                   |     Node      |
        +---------------+                                   +---------------+
        |       u       |
        +---------------+
        |       n       |
        +---------------+
        |       c       |
        +---------------+
*******************************************************************************/
namespace ge {
class PartitionedCallOpLabelMaker : public LabelMaker {
 public:
  PartitionedCallOpLabelMaker(const ComputeGraphPtr &graph, const NodePtr &owner) : LabelMaker(graph, owner) {}

  ~PartitionedCallOpLabelMaker() override {}

  virtual Status Run(uint32_t &label_index);
};
}  // namespace ge
#endif  // GE_GRAPH_PASSES_PARTITIONED_CALL_OP_LABEL_PASS_H_