かなり低レベルのアプリケーションを持っていたので、Haskell関数のアドレスを決定する必要がある状況に陥りました。私はFFI、つまりCでそれを行うことができましたが、Haskellで直接やりたいと思っています。
FFIを使用した現在のソリューションは次のとおりです。
main.hs:
{-# LANGUAGE ForeignFunctionInterface #-}
module Main where
import Foreign
import Foreign.C.Types
import Text.Printf
foreign import ccall "getFuncAddr"
getFuncAddr :: CULong
main :: IO ()
main = do
printf "0x%016x\n" (fromIntegral getFuncAddr :: Word64)
foreign export ccall func :: IO ()
func :: IO ()
func = do
printf "hello world\n"
ffi.c:
void func(void);
unsigned long getFuncAddr(void)
{
return (unsigned long) func;
}
Makefile:
all: main
./$<
objdump -D $< | grep '<func>'
main: main.hs ffi.c
ghc --make -O2 $^ -o $@
いつものように、要点としても利用できます。