Haskell FFI 导出的常量注释
const annotation for Haskell FFI exports
我将一个 Haskell 函数公开给 C/C++
foreign export ccall foo :: Ptr CInt -> CInt -> IO CInt
foo ptr len = do
list <- peekArray (fromIntegral len) ptr
-- run calculation based on list entries
return result
导出函数的签名变为
HsInt32 foo(HsPtr a1, HsInt32 a2);
但是,由于数组没有被修改,我宁愿把它作为
HsInt32 foo(const HsPtr a1, HsInt32 a2);
有没有办法自动添加此注释?
(动机是我希望它在 std::vector
inline int foo(const std::vector<int> &v)
{
return foo(v.data(), v.size());
}
不包括const_cast。
GHC 中没有用于生成带有const
注释的 C 帮助程序函数的工具。 特别是,GHC 源中的相关代码位于生成 C 存根的函数mkFExportCBits
compiler/deSugar/DsForeign.hs
中。 每个参数都被赋予一个由前缀"Hs"和构造函数名称组成的朴素的 C 类型。 无法在任何地方添加const
。
甚至没有希望让 GHC 使用用户定义的 C 类型,就像您可以使用的HsConstPtr
:允许的外部参数类型仅限于由 compiler/typecheck/TcType.hs
中的 boxedMarshalableTyCon
函数确定的类型(在 includes/HsFFI.h
中具有 C 类型的相关定义(。
另一方面,目前还不清楚为什么你不能丢弃你正在编写的包装器中的常量:
inline int foo_wrapper(const std::vector<int> &v)
{
std::vector<int> &v2 = const_cast<std::vector <int>&>(v);
return foo_haskell(v2.data(), v2.size());
}
如果这让你觉得很脏...好吧,编程是一项肮脏的工作,对吧?
相关文章:
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 什么时候在C++中返回常量引用是个好主意
- 代理对象的常量正确性
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 通过多个头文件使用常量变量
- 在cuda线程之间共享大量常量数据
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 是默认情况下分配给char数组常量的值
- Visual Studio 2019:插入多个C++风格的单行注释
- 私有类型的静态常量成员
- 类似枚举的计算常量
- 递归模板化函数不能分配给具有常量限定类型"const tt &"的变量"state"
- 为什么我可以通过引用修改常量返回
- 如何创建长度由常量参数指定的数组
- 当一个值是非常量但用常量表达式初始化时使用constexpr
- 返回常量对象引用 (getter) 和仅返回字符串有什么区别?
- 隐式常量/非常量运算符布尔
- Haskell FFI 导出的常量注释