NAME
Alien::FLTK - Build and use the Fast Light Toolkit binaries
Description
This distribution builds and installs libraries for the (experimental) 2.0.x
branch of the FLTK GUI toolkit.
Synopsis
use Alien::FLTK;
use ExtUtils::CBuilder;
my $CC = ExtUtils::CBuilder->new();
my $source = 'hello_world.cxx';
open(my $FH, '>', $source) || die '...';
syswrite($FH, <<'') || die '...'; close $FH;
#include <fltk/Window.h>
#include <fltk/Widget.h>
#include <fltk/run.h>
using namespace fltk;
int main(int argc, char **argv) {
Window *window = new Window(300, 180);
window->begin();
Widget *box = new Widget(20, 40, 260, 100, "Hello, World!");
box->box(UP_BOX);
box->labelfont(HELVETICA_BOLD_ITALIC);
box->labelsize(36);
box->labeltype(SHADOW_LABEL);
window->end();
window->show(argc, argv);
return run();
}
my $obj = $CC->compile(source => $source,
extra_compiler_flags => Alien::FLTK->cxxflags());
my $exe = $CC->link_executable(
objects => $obj,
extra_linker_flags => Alien::FLTK->ldflags()
);
print system($exe) ? 'Aww...' : 'Yay!';
END { unlink grep defined, $source, $obj, $exe; }
Methods
include_path
my $include_path = Alien::FLTK->include_path;
Returns the location of the headers installed during the build process.
library_path
my $include_path = Alien::FLTK->library_path;
Returns the location of the private libraries we made and installed during the build process.
cflags
my $cflags = Alien::FLTK->cflags;
Returns additional C compiler flags to be used.
cxxflags
my $cxxflags = Alien::FLTK->cxxflags;
Returns additional flags to be used to when compiling C++ using FLTK.
ldflags
my $ldflags = Alien::FLTK->ldflags(qw[gl images]);
Returns additional linker flags to be used. This method can automatically add appropriate flags based on how you plan on linking to fltk. Acceptable arguments are:
static
-
Returns flags to link against a static FLTK library.
FLTK's license allows static linking, btw.
gl
-
Include flags to use GL.
This is an experimental option. Depending on your system, this may also include OpenGL or MesaGL.
images
-
Include flags to use extra image formats (PNG, JPEG).
revision
my $revision = Alien::FLTK->revision;
Returns the SVN revision number of the source Alien::FLTK
was built with.
Bugs
Numerous, I'm sure.
Notes
Support Links
Issue Tracker
http://github.com/sanko/alien-fltk/issues
Please only report Alien::FLTK related bugs to this tracker. For FLTK issues, use http://github.com/sanko/fltk-perl/issues/
Commit Log
http://github.com/sanko/alien-fltk/commits/master
Homepage:
http://sanko.github.com/fltk-perl/ is the homepage of the FLTK project.
License:
http://www.perlfoundation.org/artistic_license_2_0
See the License and Legal section of this document.
Mailing List
Once I find someone to host a list for the FLTK project, I'll use it for Alien::FLTK too.
Repository
http://github.com/sanko/alien-fltk/ and you are invited to fork it.
Requirements
Once installed, Alien::FLTK depends on:
Examples
Please see the Synopsis and the files in the /example/
.
Installation
Building the fltk2 libs requires a functioning C++ compiler, bash, and (to make life easy) a version of make.
The distribution is based on Module::Build, so use the following procedure:
perl Build.PL
./Build
./Build test
./Build install
An attempt has been made to work around an incomplete set of build tools. This fallback requires ExtUtils::CBuilder and plenty of begging. Consider it alpha at best.
To Do
Please see Alien::FLTK::Todo
See Also
Acknowledgments
Author
Sanko Robinson <sanko@cpan.org> - http://sankorobinson.com/
CPAN ID: SANKO
License and Legal
Copyright (C) 2009 by Sanko Robinson <sanko@cpan.org>
This program is free software; you can redistribute it and/or modify it under the terms of The Artistic License 2.0. See the LICENSE file included with this distribution or http://www.perlfoundation.org/artistic_license_2_0. For clarification, see http://www.perlfoundation.org/artistic_2_0_notes.
When separated from the distribution, all POD documentation is covered by the Creative Commons Attribution-Share Alike 3.0 License. See http://creativecommons.org/licenses/by-sa/3.0/us/legalcode. For clarification, see http://creativecommons.org/licenses/by-sa/3.0/us/.
Alien::FLTK
is based in part on the work of the FLTK project. See http://www.fltk.org/.