in reply to Re^4: XS, raspberry pi, and a hundred bucks
in thread XS, raspberry pi, and a hundred bucks

Indeed Inline::C generates an xs distribution, you only have to use it once to bootstrap an xs module
  • Comment on Re^5: XS, raspberry pi, and a hundred bucks

Replies are listed 'Best First'.
Re^6: XS, raspberry pi, and a hundred bucks
by bliako (Abbot) on Nov 02, 2021 at 09:18 UTC

    Hmmm, yes and no. Because I did not find a straight forward way to tell Inline::C NOT to cleanup XS code after successful compilation. From its source code, the cleanup option is in {API} hash which I do not know how to affect. The very round-about way of doing this was to break the compilation by introducing an obvious error in the C code. That would leave the XS file in the build dir. Albeit broken but easily fixable. That's all based on my own experiments as documentation is a bit scarce. It would be a good feature to allow for converting the hidden XS distribution to a stand-alone module in a straight-forward way. (Edit: see Anonymous response below with proper solution)

    On the very serious other hand, NERDVANA mentions Inline::Module (unknown to me a minute ago) which provides exactly this functionality. I have not tried it yet.

    FWIW, this tells Inline::C to place the output binaries to specific directory ("unhiding" it!) - provided output dir exists. BUT I did not manage to tell it to NOT cleanup so that I can use the XS code. So I can only use the binaries. (Edit: same as above edit)

    use Inline C => Config => # dir must already exist! DIRECTORY => 'xxx' ; use Inline 'C'; # perl code ... __END__ __C__ // C code

    bw, bliako

        great! thanks for CLEAN_AFTER_BUILD (Edit: so fortunate that BrowserUK did not delete that node!)