ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/IO-AIO/Makefile.PL
(Generate patch)

Comparing IO-AIO/Makefile.PL (file contents):
Revision 1.6 by root, Fri Aug 19 01:07:27 2005 UTC vs.
Revision 1.22 by root, Mon Nov 1 22:03:43 2010 UTC

1use 5.008002;
2
1use ExtUtils::MakeMaker; 3use ExtUtils::MakeMaker;
2 4
3use Config; 5use Config;
4 6
5require "autoconf.pm"; 7if ($^O =~ /win32/i or $^O =~ /mswin/) {
6 8
9 # configuration on windows is hardcoded - as always
10
11 warn "your platform is not standards-compliant, you have to port this module first\n";
12 warn "using some hardcoded config that will not work on your system\n";
13
14 $INC = "-I/Perl/lib/CORE -I/sdk/include -I/vc98/include -I/gtk/include -I/gtk/include/pango-1.0 -I/gtk/include/glib-2.0 -I/gtk/lib/glib-2.0/include/ -I/gtk/include/freetype2";
15 $LIBS = ["-L/gtk/lib -lpthreadVC2"];
16
17} else {
18
19 $INC = "";
20 $LIBS = ['-lpthread', '-lpthreads', '-lpthreadVC2', ''];
21
7if ($^O =~ /freebsd/i) { 22 if ($^O =~ /bsd/i) {
23 print <<EOF;
24
25If you have problems with deadlocks or crashes on your system,
26make sure your perl has been linked with -lpthread (you might try
27LD_PRELOAD=/path/to/libpthread.so as a workaround). Also, pthread support
28under many BSDs is not the best - before reporting a bug in this module,
29make sure it's not an OS bug.
30
31EOF
32 }
33
34 {
35 local %ENV = %ENV;
36
37 while (my ($k, $v) = each %Config) {
38 $ENV{$k} = $v;
39 }
40
41 $ENV{MAKE} = $Config{make};
42 $ENV{SHELL} = $Config{sh};
43 $ENV{CC} = $Config{cc};
44 $ENV{CPPFLAGS} = $Config{cppflags};
45 $ENV{CFLAGS} = $Config{ccflags};
46 $ENV{LDFLAGS} = $Config{ldflags};
47 $ENV{LINKER} = $Config{ld}; # nonstandard
48
49 system $ENV{SHELL}, -c => "./configure --prefix \Q$Config{prefixexp}\E"
50 and exit $? >> 8;
51 }
52}
53
54if ($^O =~ /linux/ && $Config{usemymalloc} eq "y") {
8 print <<EOF; 55 print <<EOF;
9 56
10This package seems to deadlock under FreeBSD. As documentation on FreeBSD 57***
11threading is sorely lacking and confusing, I'll just call FreeBSD broken 58*** WARNING:
12with regards to threading. 59***
13 60*** Your perl uses it's own memory allocator (-Dusemymalloc=y),
14If you get it to work, tell me how (maybe you need to specify magical link 61*** which is known not to be threadsafe on GNU/Linux and probably
15flags despite man pthread telling me otherwise, maybe yo need special 62*** other platforms (even when not used concurrently, it trashes
16library, maybe you need magical preprocessor symbols, maybe you need to 63*** the data structures of the system malloc running concurrently),
17recompile or re-link perl with threads enabled (a bad idea) - I have no 64*** for perls up to 5.8.8 and possibly later versions.
18idea, and I no longer care). 65***
66*** If you are unsure wether your perl has been fixed, your system
67*** is safe for other reasons, or you experience spurious segfaults,
68*** please compile your perl with -Dusemymalloc=n.
69***
19 70
20EOF 71EOF
21} 72}
22
23autoconf::run_script()
24 and die "\nconfigure failed, check it's output above and autoconf/config.log\n\n";
25 73
26my $mm = MM->new({ 74my $mm = MM->new({
27 dist => { 75 dist => {
28 PREOP => 'pod2text AIO.pm | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;', 76 PREOP => 'pod2text AIO.pm | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;',
29 COMPRESS => 'gzip -9v', 77 COMPRESS => 'gzip -9v',
30 SUFFIX => '.gz', 78 SUFFIX => '.gz',
31 }, 79 },
80 depend => {
81 "AIO.c" => "libeio/eio.h libeio/xthread.h libeio/eio.c libeio/config.h",
82 },
32 NAME => "IO::AIO", 83 NAME => "IO::AIO",
33 VERSION_FROM => "AIO.pm", 84 VERSION_FROM => "AIO.pm",
34 LIBS => ['-lpthread -lrt', '-lpthread', '-lpthreads', ''], 85 INC => $INC,
86 LIBS => $LIBS,
87 EXE_FILES => ["bin/treescan"],
88 PM => {
89 'AIO.pm' => '$(INST_LIBDIR)/AIO.pm',
90 },
91 PREREQ_PM => {
92 "common::sense" => 0,
93 },
35 clean => { FILES => "autoconf/config.h autoconf/config.log autoconf/config.status" }, 94 clean => { FILES => "libeio/config.h libeio/config.log libeio/config.status" },
36}); 95});
37 96
38$mm->flush; 97$mm->flush;
39 98

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines