NAME

C::Blocks - embeding a fast C compiler directly into your Perl parser

ALPHA

This project is in Alpha. That means that it seems to mostly work on most machines. The present goal is to find and fix all the ways that C::Blocks can break. Not only can you expect some segmentation faults on at least a few operating system, but you can expect the current compiler setup API to change once the distribution has reached a greater level of stability. (The API will settle during Beta.)

DESCRIPTION

This distribution contains C::Blocks, a module that adds a few lexically scoped keywords to your Perl parser. These keywords delimit C code blocks, and (in the current implementation) the code within them is compiled during Perl's bytecode compilation phase. The keywords including cblock, clex, cshare, and csub.

In addition, this distribution contains C::Blocks::PerlAPI, which loads Perl's C API. I may eventually include similar modules for all standard C libraries, such as libstdio, libmath, etc. Since libperl is itself compiled with these libraries, I suspect that most of them will be redundant for most people.

Finally, this distribution presently includes C::Blocks::StretchyBuffer, which provides a rudimentary vector type. It is not only useful as a library, but serves an important role as a testing module. That said, it may be spun off into its own module by the time C::Blocks v1.0 is released, so you should not rely on its presence in the base distribution.

BUILD NOTES

On Debian systems using system Perl (local::lib or otherwise), the bad-symbol auto-detection runs much, much faster if you have libperl-dev installed. This is strongly recommended, if possible. If you use Perlbrew, it will not matter because your local Perl will have libperl available.

GOALS AND MILESTONES

I have a number of goals I would like to accomplish for this project. The basic set of milestones are (1) make it work, (2) test the heck out of it, (3) settle on an API, and (4) decide whether to throw in the kitchen sink.

Pre-Alpha

The goal during the pre-alpha stage is to get things mostly working on most platforms. Once this is accomplished, I will spin an Alpha release on CPAN. I declared victory on this stage when I got libperl caching working on all platforms, even though StretchyBuffer still gave trouble on Windows.

Alpha CPAN Release, v0.01 - 0.49

The goal during the alpha stage is to vastly expand the test suite to make sure that everything works properly. For the most part, this means writing lots of tests of Perl's own C API. Additional tests for things like scoping and memory duration could stand to be expanded as well. Once I feel the test suite is robust, I move on to v0.5, beta.

The single most important failing component is csub. New just-before-alpha testing indicates that this functionality does not work at all because I seem unable to obtain the expected function pointer! This seems to be due to an error in tcc's symbol lookup, but I have a very hard time believing that is actually the root of the problem. Tests need to be added and this needs to be sorted out during the Alpha stage. I also need to document how to write a csub.

The API for tweaking the compiler will still be considered in flux, so substantial library development is discouraged during Alpha.

Also, I currently get a lot of warnings saying

warning: assignment from incompatible pointer type

This is a bug with the underlying extended symbol table handling and struct type checking. I would like this to be fixed sooner rather than later.

Beta CPAN Release, v0.50 - v0.99

After the distribution hits v0.50, it'll be time to begin settling on an API to set up the compiler. The current API uses global variables, but this almost certainly can be done better.

With the settling of the API, I also hope to make it easier to write libraries that are export wrappers. The simplest example would be something that, for the moment, I am calling C::Blocks::lib. This module would make it easy to import a bunch of C::Blocks modules in one shot, i.e.

use C::Blocks::lib qw(perl gsl prima);

would be equivalent to

use C::Blocks::libperl;
use C::Blocks::libgsl;
use C::Blocks::libprima;

Of course, I've not yet decided if I want to call all libraries lib..., so this still needs some thought.

Another important thing that'll come either during Alpha or Beta is switching to call_checker and call_parser. I used the keyword API for prototyping because it was easy for me to get started, but the newer API is the preferred method for this sort of stuff.

Finally, I want to create a module that helps automate the symbol table load/dump functionality and symbol verification currently under development for use with libperl. Once it's working for libperl, I want to create author tools for Module::Build and ExtUtils::MakeMaker so that build-time symbol table caching is easy.

v1.0

When C::Blocks hits v1.0, it'll have a solid test suite and stable API. From v1.0 onward, it'll simply be a question of what to include in the distribution itself.

Simple C-based Object System?

I plan to write a module that makes it easy to write single-inheritance object oriented C code. My current plans are to steal from Prima, which does this sort of thing exceptionally well.

XS::Object::Magic

I like XS::Object::Magic, and I think I'd like to distribute a C::Blocks module with that functionality within C::Blocks itself.

Generate Inline::C, XS, ExtUtils::Depends

Right now the C code gets compiled at Perl's parse time. Once the C code is out of the prototyping stage, it would be nice to be able to automatically extract it and generate .h and .c files that can be compiled by the system's optimizing compiler. I need to write author tools that would allow this to be done using Inline::C, or to generate XS files with the proper scoping. Of course, it would also make sense for the contents of those header files to be accessible to other XS authors via ExtUtils::Depends.

Utilize ExtUtils::Depends

There is a lot of overlap between C::Blocks and ExtUtils::Depends, and undoubtedly users of C::Blocks would like to have access to functions and data structures that are made available through ExtUtils::Depends. It would be nice to provide some sort of automatic C::Blocks wrapper for ExtUtils::Depends based modules.

Threadsafe

The Tiny C Compiler uses lots of global variables and is therefore not threadsafe. I would like to contribute back to the project by encapsulating all of that global state into the compiler state object, where it belongs. Others in the tcc community have expressed interest in getting this done, so it is a welcome contribution.

SEE ALSO

This module uses a special fork of the Tiny C Compiler. The fork is located at https://github.com/run4flat/tinycc, and is distributed through the Alien package provided by Alien::TinyCCx. To learn more about the Tiny C Compiler, see http://bellard.org/tcc/ and http://savannah.nongnu.org/projects/tinycc. The fork is a major extension to the compiler that provides extended symbol table support.

For other ways of compiling C code in your Perl scripts, check out Inline::C, FFI::TinyCC, C::TinyCompiler, and XS::TCC.

For mechanisms for calling C code from Perl, see FFI::Platypus and FFI::Raw.

If you just want to mess with C struct data from Perl, see Convert::Binary::C.

If you're just looking to write fast code with compact data structures, http://rperl.org/ may be just the ticket. It produces highly optmized code from a subset of the Perl language itself.

AUTHOR

David Mertens (dcmertens.perl@gmail.com)

BUGS

Please report any bugs or feature requests for the Alien bindings at the project's main github page: http://github.com/run4flat/C-Blocks/issues.

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc C::Blocks

You can also look for information at:

ACKNOWLEDGEMENTS

This would not be possible without the amazing Tiny C Compiler or the Perl pluggable keyword work. My thanks goes out to developers of both of these amazing pieces of technology.

LICENSE AND COPYRIGHT

Code copyright 2013-2015 Dickinson College. Documentation copyright 2013-2015 David Mertens.

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.