cplusplus-th alternatives and similar packages
Based on the "Foreign" category.
Alternatively, view cplusplus-th alternatives based on common mentions on social networks and blogs.
-
erlang
A Foreign Function Interface that lets Haskell and Erlang programs communicate. -
emacs-module
Wrappers around emacs-module.h to write Emacs modules in Haskell -
greencard
Green Card, a foreign function interface pre-processor for Haskell. -
c-storable-deriving
Derivation of C-like Storable Instances -
tasty-lua
Integrate Lua tests into tasty. This package is now part of the hslua monorepo. -
hslua-module-text
Lua module providing a selected set of operations on Text. NOTE: moved into the hslua monorepo. -
hslua-module-system
HsLua module for system and directory functions. This repository has been moved to the hslua monorepo. -
hslua-module-doclayout
Lua module wrapping Text.DocLayout. -
cusolver
Haskell FFI bindings to CUDA Solver, a LAPACK-like library -
marshal-contt
A ContT-based wrapper for Haskell-to-C marshalling functions. -
foreign-storable-asymmetric
Types and instances for implementing a Storable with different peek and poke
Access the most powerful time series database as a service
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of cplusplus-th or a related project?
Popular Comparisons
README
cplusplus-th
cplusplus-th
allows you to foreign import C++ functions that are
compatible with the ccall
calling convention. It also includes
some standard library abstractions.
Example
With the following C++ function in the object file cbits/string.o
:
namespace haskell {
string* fromCString(char const* x, int length) {
return new string(x, length);
}
}
We can import it into Haskell with:
cplusplus "haskell::fromCString(char const*, int)" "cbits/string.o"
[t|CString -> Int -> IO Std__basic_string|]
Building
It works by looking up the symbol in the object file.
When using cabal, it is recommended you include the C++ file in
your c-sources
and compile it in a build hook. For example:
import Distribution.Simple
import Distribution.Simple.Setup
import Distribution.Simple.Program
import Distribution.Simple.Program.Types
import Distribution.Simple.LocalBuildInfo
import Distribution.PackageDescription
cc_flags = ["-stdlib=libc++", "-o", "cbits/string.o", "-c", "cbits/string.cc"]
main :: IO ()
main = defaultMainWithHooks simpleUserHooks {
buildHook = buildCPlusPlus
}
buildCPlusPlus :: PackageDescription -> LocalBuildInfo -> UserHooks -> BuildFlags -> IO ()
buildCPlusPlus pkg buildInfo hooks flags = do
let verb = fromFlag (buildVerbosity flags)
clang <- findProgramLocation verb "clang++"
let clang' = case clang of
Just x -> x
Nothing -> error "clang++ not on path"
runProgram verb (simpleConfiguredProgram "clang++" (FoundOnSystem clang')) cc_flags
buildHook simpleUserHooks pkg buildInfo hooks flags
Standard Library
Foreign.CPlusPlusStdLib
exports the following type class:
class CPlusPlusLand a {- haskell side -} b {- c++ side -} where
to :: a -> IO b
from :: b -> IO a
To avoid orphan instances, it implements instances for
some numeric types, String
and ByteString
.
Compatability
- Static functions are simply the arguments.
- Static member functions take the object as the first argument.
- Functions via a vtable are not possible.
- Inline functions are not possible.
- instantiating templates is not possible.