1 | If you read this file _as_is_, just ignore the funny characters you see.
|
---|
2 | It is written in the POD format (see pod/perlpod.pod) which is specially
|
---|
3 | designed to be readable as is.
|
---|
4 |
|
---|
5 | =head1 NAME
|
---|
6 |
|
---|
7 | README.qnx - Perl version 5 on QNX
|
---|
8 |
|
---|
9 | =head1 DESCRIPTION
|
---|
10 |
|
---|
11 | As of perl5.7.2 all tests pass under:
|
---|
12 |
|
---|
13 | QNX 4.24G
|
---|
14 | Watcom 10.6 with Beta/970211.wcc.update.tar.F
|
---|
15 | socket3r.lib Nov21 1996.
|
---|
16 |
|
---|
17 | As of perl5.8.1 there is at least one test still failing.
|
---|
18 |
|
---|
19 | Some tests may complain under known circumstances.
|
---|
20 |
|
---|
21 | See below and hints/qnx.sh for more information.
|
---|
22 |
|
---|
23 | Under QNX 6.2.0 there are still a few tests which fail.
|
---|
24 | See below and hints/qnx.sh for more information.
|
---|
25 |
|
---|
26 | =head2 Required Software for Compiling Perl on QNX4
|
---|
27 |
|
---|
28 | As with many unix ports, this one depends on a few "standard"
|
---|
29 | unix utilities which are not necessarily standard for QNX4.
|
---|
30 |
|
---|
31 | =over 4
|
---|
32 |
|
---|
33 | =item /bin/sh
|
---|
34 |
|
---|
35 | This is used heavily by Configure and then by
|
---|
36 | perl itself. QNX4's version is fine, but Configure
|
---|
37 | will choke on the 16-bit version, so if you are
|
---|
38 | running QNX 4.22, link /bin/sh to /bin32/ksh
|
---|
39 |
|
---|
40 | =item ar
|
---|
41 |
|
---|
42 | This is the standard unix library builder.
|
---|
43 | We use wlib. With Watcom 10.6, when wlib is
|
---|
44 | linked as "ar", it behaves like ar and all is
|
---|
45 | fine. Under 9.5, a cover is required. One is
|
---|
46 | included in ../qnx
|
---|
47 |
|
---|
48 | =item nm
|
---|
49 |
|
---|
50 | This is used (optionally) by configure to list
|
---|
51 | the contents of libraries. I will generate
|
---|
52 | a cover function on the fly in the UU directory.
|
---|
53 |
|
---|
54 | =item cpp
|
---|
55 |
|
---|
56 | Configure and perl need a way to invoke a C
|
---|
57 | preprocessor. I have created a simple cover
|
---|
58 | for cc which does the right thing. Without this,
|
---|
59 | Configure will create its own wrapper which works,
|
---|
60 | but it doesn't handle some of the command line arguments
|
---|
61 | that perl will throw at it.
|
---|
62 |
|
---|
63 | =item make
|
---|
64 |
|
---|
65 | You really need GNU make to compile this. GNU make
|
---|
66 | ships by default with QNX 4.23, but you can get it
|
---|
67 | from quics for earlier versions.
|
---|
68 |
|
---|
69 | =back
|
---|
70 |
|
---|
71 | =head2 Outstanding Issues with Perl on QNX4
|
---|
72 |
|
---|
73 | There is no support for dynamically linked libraries in QNX4.
|
---|
74 |
|
---|
75 | If you wish to compile with the Socket extension, you need
|
---|
76 | to have the TCP/IP toolkit, and you need to make sure that
|
---|
77 | -lsocket locates the correct copy of socket3r.lib. Beware
|
---|
78 | that the Watcom compiler ships with a stub version of
|
---|
79 | socket3r.lib which has very little functionality. Also
|
---|
80 | beware the order in which wlink searches directories for
|
---|
81 | libraries. You may have /usr/lib/socket3r.lib pointing to
|
---|
82 | the correct library, but wlink may pick up
|
---|
83 | /usr/watcom/10.6/usr/lib/socket3r.lib instead. Make sure
|
---|
84 | they both point to the correct library, that is,
|
---|
85 | /usr/tcptk/current/usr/lib/socket3r.lib.
|
---|
86 |
|
---|
87 | The following tests may report errors under QNX4:
|
---|
88 |
|
---|
89 | ext/Cwd/Cwd.t will complain if `pwd` and cwd don't give
|
---|
90 | the same results. cwd calls `fullpath -t`, so if you
|
---|
91 | cd `fullpath -t` before running the test, it will
|
---|
92 | pass.
|
---|
93 |
|
---|
94 | lib/File/Find/taint.t will complain if '.' is in your
|
---|
95 | PATH. The PATH test is triggered because cwd calls
|
---|
96 | `fullpath -t`.
|
---|
97 |
|
---|
98 | ext/IO/lib/IO/t/io_sock.t: Subtests 14 and 22 are skipped due to
|
---|
99 | the fact that the functionality to read back the non-blocking
|
---|
100 | status of a socket is not implemented in QNX's TCP/IP. This has
|
---|
101 | been reported to QNX and it may work with later versions of
|
---|
102 | TCP/IP.
|
---|
103 |
|
---|
104 | t/io/tell.t: Subtest 27 is failing. We are still investigating.
|
---|
105 |
|
---|
106 | =head2 QNX auxiliary files
|
---|
107 |
|
---|
108 | The files in the "qnx" directory are:
|
---|
109 |
|
---|
110 | =over 4
|
---|
111 |
|
---|
112 | =item qnx/ar
|
---|
113 |
|
---|
114 | A script that emulates the standard unix archive (aka library)
|
---|
115 | utility. Under Watcom 10.6, ar is linked to wlib and provides the
|
---|
116 | expected interface. With Watcom 9.5, a cover function is
|
---|
117 | required. This one is fairly crude but has proved adequate for
|
---|
118 | compiling perl.
|
---|
119 |
|
---|
120 | =item qnx/cpp
|
---|
121 |
|
---|
122 | A script that provides C preprocessing functionality. Configure can
|
---|
123 | generate a similar cover, but it doesn't handle all the command-line
|
---|
124 | options that perl throws at it. This might be reasonably placed in
|
---|
125 | /usr/local/bin.
|
---|
126 |
|
---|
127 | =back
|
---|
128 |
|
---|
129 | =head2 Outstanding issues with perl under QNX6
|
---|
130 |
|
---|
131 | The following tests are still failing for Perl 5.8.1 under QNX 6.2.0:
|
---|
132 |
|
---|
133 | op/sprintf.........................FAILED at test 91
|
---|
134 | lib/Benchmark......................FAILED at test 26
|
---|
135 |
|
---|
136 | This is due to a bug in the C library's printf routine.
|
---|
137 | printf("'%e'", 0. ) produces '0.000000e+0', but ANSI requires
|
---|
138 | '0.000000e+00'. QNX has acknowledged the bug.
|
---|
139 |
|
---|
140 | =head1 AUTHOR
|
---|
141 |
|
---|
142 | Norton T. Allen (allen@huarp.harvard.edu)
|
---|
143 |
|
---|