Implementation Of Quirks
Function X doesn't seem to work on Perl for Win32. Why not?
alarm(), chroot(), fork(), getpgrp(), getppid(), getpriority(),
getpwnam(), getgrnam(), getpwuid(), getgrgid(), getpwent(),
getgrent(), setpwent(), setgrent(), endpwent(), endgrent(), kill(),
link(), msgctl(), msgget(), msgrcv(), msgsnd(), semctl(), semget(),
semop(), setpgrp(), setpriority(), shmctl(), shmget(), shmread(),
shmwrite(), symlink(), syscall(), times(), wait(), waitpid(),
getnetbyname(), getnetbyaddr(), getnetent(), getprotoent(),
getservent(), sethostent(), setnetent(), setprotoent(), setservent(),
endhostent(), endnetent(), endprotoent(), endservent(), socketpair()
- mkdir: The second argument, MODE, is ignored.
- stat: UNIX-specific measurements such as blocks, inode, gid, and uid are returned, but undefined.
Function Y doesn't seem to work under PerlIS. Why not?
- change the current working directory
- spawn another process, using backticks (``), the system() or exec() functions, Win32::Spawn() or any of the Win32::Process functions
What's the difference between Perl for Win32 and the standard distribution?
- The standard distribution's build procedure depends on UNIX shell scripts and make files not applicable to the Win32 world.
- Many UNIXish functions, modules and scripts are either unavailable, flaky, or just plain broke in the Perl for Win32 implementation.
- The standard distribution is in source form; Perl for Win32 is in binary and source form.
- Documentation for the standard distribution is in POD format; documentation for Perl for Win32 are in HTML format.
- Most standard tools that UNIX perl programmers employ in their scripts without a second thought (such as "sendmail") are not available on Windows NT. Even fewer are available on Windows 95.
- The difference between binary and text files under Win32 matters, which it doesn't for UNIX. inary files can get mangled by treating them like text files.
- Files and drives are addressed differently on Windows platforms than on UNIX. In particular, each drive has a letter (like "C:"), and directories in a path are separated by "\" rather than "/".
Finally, there's a difference in culture. perl is developed and maintained by the people who use it, and there's a collaborative nature to the progress of that product. Conversely, Perl for Win32 is de facto owned by ActiveWare, which has neither the participatory nature of a loose-knit user-developer community nor the responsiveness of a commercial software company.
What's the difference between running Perl for Win32 on Windows NT versus running it on Windows 95?
- The command interpreter for Windows NT, cmd.exe, is different than the command interpreter for Windows 95, command.com. command.com has some archaic ways of taking arguments and returning error codes that don't jibe with cmd.exe. ActiveWare has developed a work-around program, cmd32.exe, which will take the place of cmd.exe on Windows 95 for executing programs from a Perl script.
- The Win32::NetAdmin, Win32::NetResource, and Win32::EventLog modules will not run on Windows 95.
- Some functions that work on Windows NT reportedly do not work or are buggy on Windows 95. An example is flock().
- Finally, many helpful programs that are available on Windows NT are not there on Windows 95. "hostname", for example, is not available on Windows 95. [Others? -ESP]
If you're worried about using a feature from one or the other, check the result of the function Win32::IsWinNT() to see what OS you're running on.
Why don't my examples from the Camel book work?
Some of the examples in the Camel book will work. Some will not. If they fail, it's because either the functions used are not available, the external tools used are not available, or the modules used are not available. Usually, for small scripts, it's not to hard to fiddle with them until they come out correct (Camel and Llama books are good learning tools. However, one of the things you learn as a Perl for Win32 programmer is how to port UNIX-targeted scripts and modules to Perl for Win32. So, get used to it.
The Perl motto is "There's More Than One Way To Do It." The Perl for Win32 motto could be "It's A Good Thing That There's More Than One Way To Do It, Because Most Of The Ways Don't Work."
5.6. Why doesn't standard library module Z work?
How do I make a UNIX-based script work?
- Calls to functions unimplemented in Perl for Win32.
- Calls to standard library modules or CPAN modules that aren't available on Perl for Win32, or that don't work.
- system() or backtick (``) calls to system tools that aren't available on Perl for Win32.
- Reading and writing files that may be binary.
- File-system dependent path names and path name parsing. Watch for "/" rather than "\\", and hard-coded UNIX paths like "/usr/lib".
- Version require's, like "require 5.003;" or "require Sockets 1.03;". Check to see if the script or module really requires the new version.
Of course, it should go without saying that for everything you take out you'll have to put in a work-around.
Once you've worked around UNIX dependencies in the script or module, try running it through the debugger to see if what you did helps. If the script or module comes with a ".t" test file, try using that to test your changed version.
If you _do_ make a change to a UNIX-based script or module, please let the author know. They will sometimes be gracious enough to make changes that will let the program run on Perl for Win32. If the author won't change the program, ask if you can make the altered version available to other users.
0 comments:
Post a Comment