// src/binaryen-c.autogen.cpp

BINARYEN_API BinaryenExpressionRef
BinaryenCallRef(BinaryenModuleRef module,
                BinaryenExpressionRef target,
                BinaryenExpressionRef* operands,
                BinaryenIndex num_operands,
                uint32_t isReturn,
                BinaryenType type) {
  std::vector<Expression*> operands_list;
  for (BinaryenIndex i = 0; i < num_operands; i++) {
    operands_list.push_back((Expression*)operands[i]);
  }
  return static_cast<Expression*>(
    Builder(*(Module*)module)
      .makeCallRef(target, operands_list, isReturn, Type(type)));
}

BINARYEN_API BinaryenExpressionRef BinaryenRttCanon(BinaryenModuleRef module,
                                                    BinaryenType heapType) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeRttCanon(HeapType(heapType)));
}

BINARYEN_API BinaryenExpressionRef BinaryenRttSub(BinaryenModuleRef module,
                                                  BinaryenExpressionRef parent,
                                                  BinaryenType heapType) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeRttSub(parent, HeapType(heapType)));
}

BINARYEN_API BinaryenExpressionRef
BinaryenStructNew(BinaryenModuleRef module,
                  BinaryenExpressionRef rtt,
                  BinaryenExpressionRef* operands,
                  BinaryenIndex num_operands) {
  std::vector<Expression*> operands_list;
  for (BinaryenIndex i = 0; i < num_operands; i++) {
    operands_list.push_back((Expression*)operands[i]);
  }
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeStructNew(rtt, operands_list));
}

BINARYEN_API BinaryenExpressionRef BinaryenStructGet(BinaryenModuleRef module,
                                                     uint32_t index,
                                                     BinaryenExpressionRef ref,
                                                     uint32_t signed_,
                                                     BinaryenType type) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeStructGet(index, ref, signed_, Type(type)));
}

BINARYEN_API BinaryenExpressionRef
BinaryenStructSet(BinaryenModuleRef module,
                  uint32_t index,
                  BinaryenExpressionRef value,
                  BinaryenExpressionRef ref) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeStructSet(index, value, ref));
}

BINARYEN_API BinaryenExpressionRef
BinaryenArrayNew(BinaryenModuleRef module,
                 BinaryenExpressionRef rtt,
                 BinaryenExpressionRef size,
                 BinaryenExpressionRef init) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeArrayNew(rtt, size, init));
}

BINARYEN_API BinaryenExpressionRef BinaryenArrayGet(BinaryenModuleRef module,
                                                    BinaryenExpressionRef index,
                                                    BinaryenExpressionRef ref,
                                                    uint32_t signed_) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeArrayGet(index, ref, signed_));
}

BINARYEN_API BinaryenExpressionRef BinaryenArraySet(BinaryenModuleRef module,
                                                    BinaryenExpressionRef value,
                                                    BinaryenExpressionRef index,
                                                    BinaryenExpressionRef ref) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeArraySet(value, index, ref));
}

BINARYEN_API BinaryenExpressionRef BinaryenArrayLen(BinaryenModuleRef module,
                                                    BinaryenExpressionRef ref) {
  return static_cast<Expression*>(Builder(*(Module*)module).makeArrayLen(ref));
}

BINARYEN_API BinaryenExpressionRef BinaryenRefTest(BinaryenModuleRef module,
                                                   BinaryenExpressionRef rtt,
                                                   BinaryenExpressionRef ref) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeRefTest(rtt, ref));
}

BINARYEN_API BinaryenExpressionRef BinaryenRefCast(BinaryenModuleRef module,
                                                   BinaryenExpressionRef rtt,
                                                   BinaryenExpressionRef ref) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeRefCast(rtt, ref));
}

BINARYEN_API BinaryenExpressionRef BinaryenBrOn(BinaryenModuleRef module,
                                                uint32_t op,
                                                const char* name,
                                                BinaryenExpressionRef rtt,
                                                BinaryenExpressionRef ref) {
  return static_cast<Expression*>(
    Builder(*(Module*)module).makeBrOn(BrOnOp(op), name, rtt, ref));
}
