Commit | Line | Data |
867988ae |
1 | after 5.003_05: |
2 | PERLLIB_PREFIX was not active if it matches an element of @INC |
3 | as a whole. |
4 | Do not need PERL_SBRK if crtdll-revision is >= 50. |
5 | Use -Zsmall-conv if crtdll-revision is >= 50 (in static perl!). |
6 | :7: warning: #warning <dirent.h> requires <sys/types.h> |
7 | We compile miniperl static. It cannot fork, thus there may be |
8 | problems with pipes (since HAS_FORK is in |
9 | place). Pipes are required by makemaker. |
10 | We compile perl___.exe A.OUT and dynamic. It should be able to |
11 | fork. |
12 | If we can fork, we my_popen by popen unless "-|". Thus we |
13 | write a cooky "-1" into the pid array to indicate |
14 | this. |
15 | Apparently we can fork, and we can load dynamic extensions |
16 | now, though probably not simultaneously. |
17 | *DB tests corrected for OS/2 one-user stat[2]. |
18 | /bin/sh is intercepted and replaced by SH_PATH. |
19 | Note that having '\\' in the command line of one-arg `system' |
20 | would trigger call via shell. |
21 | Segfault with system {'ls'} 'blah'; corrected. |
22 | Documentation of OS/2-different features added to main PODs. |
23 | New buitins in Cwd:: |
24 | |
25 | Cwd::current_drive |
26 | Cwd::sys_chdir - leaves drive as it is. |
27 | Cwd::change_drive |
28 | Cwd::sys_is_absolute - has drive letter and is_rooted |
29 | Cwd::sys_is_rooted - has leading [/\\] (maybe |
30 | after a drive) |
31 | Cwd::sys_is_relative - changes with current dir |
32 | Cwd::sys_cwd - Interface to cwd from EMX. |
33 | Cwd::sys_abspath(name, dir) |
34 | - Really really odious |
35 | function. Returns absolute |
36 | name of file which would |
37 | have 'name' if CWD were 'dir'. |
38 | Dir defaults to the current dir. |
39 | Cwd::extLibpath [type] - Get/set current value of extended |
40 | Cwd::extLibpath_set - library search path. |
41 | path [type] |
42 | The optional last argument redirects |
43 | to END-path if true, |
44 | default is to search BEGIN-path. |
45 | (Note that some of these may be moved to different |
46 | libraries - eventually). |
47 | Executables: |
48 | perl - can fork, can dynalink (but not simultaneously) |
49 | perl_ - can fork, cannot dynalink |
50 | perl__ - same as perl___, but PM. |
51 | perl___ - cannot fork, can dynalink. |
52 | The build of the first one - perl - is rather convoluted, and |
53 | requires a build of miniperl_. |
55497cff |
54 | |
55 | after 5.003_07: |
56 | custom tmpfile and tmpname which may use $TMP, $TEMP. |
57 | all the calls to OS/2 API wrapped so that it is safe to use |
58 | them under DOS (may die(), though). |
59 | Tested that popen works under DOS with modified PDKSH and RSX. |
60 | File::Copy works under DOS. |
61 | MakeMaker modified to work under DOS (perlmain.c.tmp and sh -c true). |
72ea3524 |
62 | |
63 | after 5.003_08: |
64 | OS2::PrfDB exports symbols as documented; |
65 | should work on OS/2 2.1 again. |
66 | uses reliable signals when spawing. |
67 | do not use popen() any more - no intermediate shell unless needed. |
df3ef7a9 |
68 | |
69 | after 5.003_11: |
70 | Functions emx_{malloc,realloc,calloc,free} are exported from DLL. |
71 | get_sysinfo() bugs corrected (flags were not used and wrongly defined). |
44a8e56a |
72 | |
73 | after 5.003_20: |
74 | _isterm is substituted instead of isatty, s?random instead of srand. |
75 | `register' disabled if -DDEBUGGING and not AOUT build: stupid SD386. |
76 | 3-argument select() was stomping over memory. |
e29f6e02 |
77 | |
78 | after 5.003_21: |
79 | Can start scripts by executing 'dir/script' and |
80 | 'script.sh'. Form without extension will call shell only if |
81 | the specified file exists (will not look on path) (to prohibit |
82 | trying to run shell commands directly). - Needed by magic.t. |
aa689395 |
83 | |
84 | after 5.003_27: |
85 | ALTERNATE_SHEBANG="extproc " supported, thus options on this |
86 | line are processed (possibly twice). -S is made legal on such |
87 | a line. This -S -x is not needed any more. |
88 | perl.dll may be used from non-EMX programs (via PERL_SYS_INIT |
89 | - the caller should have valid variable "env" with |
90 | environment). Known problems: $$ does not work - is 0, waitpid |
91 | returns immediately, thus Perl cannot wait for completion of |
92 | started programs. |
d8c2d278 |
93 | |
367f3c24 |
94 | after 5.004_01: |
95 | flock emulation added (disable by setting env PERL_USE_FLOCK=0), |
96 | thanks to Rocco Caputo; |
97 | RSX bug with missing waitpid circomvented; |
98 | -S bug with full path with \ corrected. |
99 | |
d8c2d278 |
100 | before 5.004_02: |
101 | -S switch to perl enables a search with additional extensions |
102 | .cmd, .btm, .bat, .pl as well. This means that if you have |
103 | mycmd.pl or mycmd.bat on PATH, |
104 | perl -S mycmd |
105 | will work. Perl will also look in the current directory first. |
106 | Moreover, a bug with \; in PATH being non-separator is fixed. |
84902520 |
107 | |
fb73857a |
108 | after 5.004_03: |
109 | $^E tracks calls to CRT now. (May break if Perl masks some |
110 | changes to errno?) |
111 | $0 may be edited to longer lengths (at least under OS/2). |
112 | OS2::REXX->loads looks in the OS/2-ish fashion too. |
dd96f567 |
113 | |
91643db9 |
114 | after 5.004_04: |
115 | Default perl.exe was built with a shorter stack than expected. |
116 | Strip extensions DLLs too (unless debugging build). |
117 | ./os2.c being RO could stop cp. |
118 | When starting scripts, Perl will find them on path (using the same |
119 | extensions as for -S command-line switch). If it finds magic |
120 | `extproc ' or `#!' cookies, it will start the scripts directly. |
121 | May use `cmd /c more <' as a pager. |
122 | If a program could not be started, this might have been hidden. |
123 | End of pipe was closed twice when `open'ing a pipeline. |
124 | |
dd96f567 |
125 | after 5.004_53: |
126 | Minimal thread support added. One needs to manually move pthread.h |
3aefca04 |
127 | |
128 | after 5.004_64: |
129 | Make DLL names different if thread-enabled. |
130 | Emit more informative internal DLL descriptions. |
2c2e0e8c |
131 | |
132 | 5.004_72: |
133 | Updated OS2::Process (v0.2) included. |
134 | |
135 | after 5.004_73: |
136 | Fixed a bug with argv not NULL-terminated when starting scripts. |
137 | Support all the forms of starting scripts. |
138 | Support killing a child when receiving a signal during system() |
139 | (in two stage, on first send the same signal, on the next |
140 | send SIGKILL). |
141 | Add the same logic for scripts as in pdksh, including |
142 | stripping the path from #! line if needed, |
143 | calling EXECSHELL or COMSPEC for magic-less scripts; |
144 | Now pdksh is called only if one-arg system()/friends contains |
145 | metachars, or if magic-line asks for sh, or there is no magic |
146 | line and EXECSHELL is set to sh. |
147 | Shell is supplied the original command line if possible. |
017f25f1 |
148 | |
149 | after 5.005_02: |
150 | Can start PM programs from non-PM sessions by plain system() |
151 | and friends. Can start DOS/Win programs. Can start |
152 | fullscreen programs from non-fullscreen sessions too. |
153 | In fact system(P_PM,...) was broken. |
154 | We mangle the name of perl*.DLL, to allow coexistence of different |
155 | versions of Perl executables on the system. Mangling of |
156 | names of extension DLL is also changed, thus running two |
157 | different versions of the executable with loaded |
158 | extensions should not lead to conflicts (since |
159 | extension-full-name and Perl-version mangling work in the |
160 | same set ot 576 possible keys, this may lead to clashes). |
161 | $^E was reset on the second read, and contained ".\r\n" at the end. |
4bfbfac5 |
162 | |
163 | after 5.005_53: |
e96326af |
164 | Would segfault system()ing non-existing program; |
165 | AOUT build was hosed; |
4bfbfac5 |
166 | warning-test for getpriority() might lock the system hard on |
167 | pre-fixpak22 configuration (calling getpriority() on |
168 | non-existing process triggers a system-wide bug). |
169 | |
4e3d4845 |
170 | |
171 | PrfDB was using a bug in processing XSUBs returning U32. |
172 | |
4bfbfac5 |
173 | Variable $OS2::emx_rev implemented (string and numberic values |
174 | are the same as C variables _emx_rev and _emx_vprt). |
175 | Variable $OS2::emx_env implemented (same as C variable _emx_env). |
176 | Variable $OS2::os_ver implemented (_osmajor + 0.001 * _osminor). |
177 | |
178 | Improved centralized management of HAB and HMQ. To get Perl's |
179 | HAB, call perl_hab_GET(). (After the initial call one |
180 | can use Perl_hab instead.) To require Perl's HMQ, |
181 | call perl_hmq_GET(), to release it call perl_hmq_UNSET(), |
182 | to obtain it between these calls use Perl_hmq. |
183 | HMQ management is refcounted, and the program will morph |
184 | itself into/from PM if required. |
185 | If perl.h cannot be included, hab may be obtained by Perl_hab_GET(). |
186 | |
187 | New function OS2::Error(do_harderror,do_exception). Returns |
188 | undef if it was not called yet, otherwise bit 1 is |
189 | set if on previous call do_harderror was enabled, bit |
190 | 2 is set if if on previous call do_exception was enabled. |
191 | This function enables/disables error popups associated with |
192 | hardware errors (Disk not ready etc.) and software exceptions. |
193 | |
194 | New function OS2::Errors2Drive(drive). Returns undef if it was |
195 | not called yet, otherwise return false if Errors were |
196 | not requested to be written to a hard drive, or the |
197 | drive letter if this was requested. |
198 | This function may redirect error popups associated with |
199 | hardware errors (Disk not ready etc.) and software exceptions |
200 | to the file POPUPLOG.OS2 at the root directory of the |
201 | specified drive. Overrides OS2::Error() specified by |
202 | individual programs. Given argument undef will |
203 | disable redirection. Has global effect, persists |
204 | after the application exits. |
205 | |
206 | New function OS2::SysInfo(). Returns a hash with system information. |
207 | The keys of the hash are |
208 | |
209 | MAX_PATH_LENGTH, MAX_TEXT_SESSIONS, MAX_PM_SESSIONS, |
210 | MAX_VDM_SESSIONS, BOOT_DRIVE, DYN_PRI_VARIATION, |
211 | MAX_WAIT, MIN_SLICE, MAX_SLICE, PAGE_SIZE, |
212 | VERSION_MAJOR, VERSION_MINOR, VERSION_REVISION, |
213 | MS_COUNT, TIME_LOW, TIME_HIGH, TOTPHYSMEM, TOTRESMEM, |
214 | TOTAVAILMEM, MAXPRMEM, MAXSHMEM, TIMER_INTERVAL, |
215 | MAX_COMP_LENGTH, FOREGROUND_FS_SESSION, |
216 | FOREGROUND_PROCESS |
217 | |
218 | New function OS2::BootDrive(force). Returns a letter without colon. |
219 | |
220 | New functions OS2::MorphPM(serve)/OS2::UnMorphPM(serve). Transforms |
221 | the current application into a PM application and back. |
222 | The argument true means that a real message loop is |
223 | going to be performed. |
224 | OS2::MorphPM() returns the PM message queue handle as an integer. |
225 | |
226 | New function OS2::Serve_Messages(force). Fake on-demand |
227 | retrieval of outstanding PM messages. If force is false, |
228 | will not dispatch messages if a real message loop is known to |
229 | be present. Returns number of messages retrieved. |
230 | Dies with "QUITing..." if WM_QUIT message is obtained. |
231 | |
232 | New function OS2::Process_Messages(force [, cnt]). Retrieval |
233 | of PM messages until window creation/destruction. |
234 | If force is false, will not dispatch messages |
235 | if a real message loop is known to be present. |
236 | Returns change in number of windows. If cnt is given, |
237 | it is incremented by the number of messages retrieved. |
238 | Dies with "QUITing..." if WM_QUIT message is obtained. |
239 | |
5838269b |
240 | after 5.005_54: |
241 | Opening pipes from/to processes could fail if (un)appropriate |
242 | combination of STDIN/STDOUT was closed. |
243 | |
244 | If the only shell-metachars of a command are ' 2>&1' at the |
245 | end of a command, it is executed without calling the external shell. |
ed344e4f |
246 | |
247 | after 5.005_57: |
248 | Make UDP sockets return correct caller address (OS2 API bug); |
249 | Enable TCPIPV4 defines (works with Warp 3 IAK too?!); |
250 | Force Unix-domain sockets to start with "/socket", convert |
251 | '/' to '\' in the calls; |
252 | Make C<system 1, $cmd> to treat $cmd as in C<system $cmd>; |
253 | Autopatch Configure; |
254 | Find name and location of g[nu]patch.exe; |
255 | Autocopy perl????.dll to t/ when testing; |
256 | |
257 | after 5.005_62: |
258 | Extract a lightweight DLL access module OS2::DLL from OS2::REXX |
259 | which would not load REXX runtime system; |
260 | Allow compile with os2.h which loads os2tk.h instead of os2emx.h; |
261 | Put the version of EMX CRTL into -D define; |
262 | Use _setsyserror() to store last error of OS/2 API for $^E; |
263 | New macro PERL_SYS_INIT3(argvp, argcp, envp); |
264 | Make Dynaloader return info on the failing module after failed dl_open(); |
265 | OS2::REXX test were done for interactive testing (were writing |
266 | "ok" to stderr); |
267 | system() and friends return -1 on failure (was 0xFF00); |
268 | Put the full name of executable into $^X |
269 | (alas, uppercased - but with /); |
270 | t/io/fs.t was failing on HPFS386; |
271 | Remove extra ';' from defines for MQ operations. |
5ba48348 |
272 | |
273 | pre 5.6.1: |
274 | Resolved: "Bad free()" messages (e.g., from DB_File) with -Zomf build. |
275 | The reason was: when an extension DLL was linked, the order of |
276 | libraries was similar to this: |
277 | f1.obj f2.obj libperl.lib -llibr1 -llibr2 |
278 | (with C RTL implicitly after this). When libperl.lib overrides |
279 | some C RTL functions, they are correctly resolved when mentioned |
280 | in f1.obj and f2.obj. However, the resolution for libr1.lib and |
281 | libr2.lib is implementation-dependent. |
282 | |
283 | With -Zomf linking the symbols are resolved for libr1.lib and |
284 | libr2.lib *only if* they reside in .obj-file-sections of libperl.lib |
285 | which were already "picked up" for symbols in f1.obj f2.obj. |
286 | However, libperl.lib is an import library for a .DLL, so *each |
287 | symbol in libperl.lib sits in its own pseudo-section*! |
288 | |
289 | Corollary: only those symbol from libperl.lib which were already |
290 | mentioned in f1.obj f2.obj would be used for libr1.lib and |
291 | libr2.lib. Example: if f1.obj f2.obj do not mention calloc() but |
292 | libr1.lib and libr2.lib do, then .lib's will get calloc() of C RTL, |
293 | not one of libperl.lib. |
294 | |
295 | Solution: create a small duplicate of libperl.lib with overriding |
296 | symbols only. Put it *after* -llibr1 -llibr2 on the link line. |
297 | Map strdup() and putenv() to Perl_strdup() and Perl_putenv() |
298 | inside this library. |
299 | |
300 | Resolved: rmdir() and mkdir() do not accept trailing slashes. |
301 | Wrappers are implemented. |
302 | Resolved: when loading modules, FP mask may be erroneously changed by |
303 | _DLLInitTerm() (e.g., TCP32IP). |
304 | Solutions: a) dlopen() saves/restores the FP mask. |
305 | b) When starting, reset FP mask to a sane value |
306 | (if the DLL was compile-time linked). |
307 | New functions in package OS2: |
308 | unsigned _control87(unsigned new,unsigned mask) # as in EMX |
309 | unsigned get_control87() |
310 | # with default values good for handling exception mask: |
311 | unsigned set_control87_em(new=MCW_EM,mask=MCW_EM) |
312 | Needed to guard against other situations when the FP mask is |
313 | stompted upon. Apparently, IBM used a compiler (for some period |
314 | of time around '95?) which changes FP mask right and left... |
315 | Resolved: $^X was always uppercased (cosmetic). Solution: |
316 | use argv[0] if it differs from what the OS returns only in case. |
317 | Resolved: when creating PM message queues, WinCancelShutdown() was |
318 | not called even if the application said that it would not serve |
319 | messages in this queue. Could result in PM refusing to shutdown. |
320 | |
321 | Solution: resolve WinCancelShutdown at run time, keep the refcount |
322 | of who is going to serve the queue. |
323 | Resolved: Perl_Deregister_MQ() segfaulted (pid/tid not initialized). |
324 | Resolved: FillWinError() would not fetch the error. |
325 | Solution: resolve WinGetLastError at run time, call it. |
326 | Resolved: OS2::REXX would ignore arguments given to a Perl function |
327 | imported into the REXX compartment via REXX_eval_with(). |
328 | Resolved: OS2::REXX would treat arguments given to a Perl function |
329 | imported into the REXX compartment via _register() as ASCIIZ |
330 | strings inside of binary strings. |
331 | Resolved: OS2::REXX did not document _register(). |
332 | Resolved: OS2::REXX would not report the error to REXX if an error |
333 | condition appeared during a call to Perl function from REXX |
334 | compartment. As a result, the return string was not initialized. |
335 | A complete example of a mini-application added to OS2::REXX. |
335bd836 |
336 | README.os2 updated to reflect the current state of Perl. |
d88df687 |
337 | |
338 | pre 5.6.2: |
339 | aout build: kid bootstrap_* were not associated with XS. |
340 | bldlevel did not contain enough info. |
341 | extLibpath* was failing on the call of the second type. |
342 | Configure defines flushNULL now (EMX -Zomf bug broke autodetection). |
343 | Configure did not find SIGBREAK. |
344 | extLibpath supports LIBSTRICT, better error detection. |
345 | crypt() used if present in -lcrypt or -lufc. |
346 | dumb getpw*(), getgr*() etc. supported; as in EMX, but if no |
347 | $ENV{PW_PASSWD}, the passwd field contains a string which |
348 | cannot be returned by crypt() (for security reasons). |
349 | The unwound recursion in detecting executable by script was |
350 | using static buffers. Thus system('pod2text') would fail if the |
351 | current directory contained an empty file named 'perl'. |
352 | Put ordinals in the base DLL. |
353 | Enable EXE-compression. |
354 | Load time (ms): Without /e:2: 70.6; With /e:2: 75.3; Lxlite: 62.8 |
355 | Size drops from 750K to 627K, with lxlite to 515K. |
356 | lxlite /c:max gives 488K, but dumps core in t/TEST |
357 | os2ish.h defines SYSLOG constants ==> Sys::Syslog works. |
358 | Corrected warnings related to OS/2 code. |
359 | At one place = was put instead of ==. |
360 | Setting $^E should work. |
361 | Force "SYS0dddd=0xbar: " to error messages and to dlerror(). |
362 | ($^E == 2 printed SYS0002 itself, but 110 did not.) |
363 | $OS2::nsyserror=0 switches off forcing SYSdddd on $^E. |
364 | perl_.exe does not require PM dlls any more (symbols resolved at |
365 | runtime on the as needed basis). |
366 | OS2::Process: |
367 | get/set: term size; codepages; screen's cursor; screen's contents |
368 | reliable session name setting; |
369 | process's parent pid, and the session id; |
370 | switching to and enumeration of sessions |
371 | window hierarchy inspection |
372 | post a message to a window |
373 | More robust getpriority() on older Warps. |