home *** CD-ROM | disk | FTP | other *** search
/ Peanuts NeXT Software Archives / Peanuts-1.iso / CDROM / FAQs / Unix / developer < prev    next >
Encoding:
Internet Message Format  |  1996-09-24  |  70.3 KB

  1. Path: informatik.tu-muenchen.de!lrz-muenchen.de!uni-erlangen.de!news.tu-chemnitz.de!zrz.TU-Berlin.DE!news.uni-ulm.de!rz.uni-karlsruhe.de!blackbush.xlink.net!tank.news.pipex.net!pipex!news.mathworks.com!news-peer.gsl.net!news.gsl.net!news-res.gsl.net!news.gsl.net!portc01.blue.aol.com!newsstand.cit.cornell.edu!news.acsu.buffalo.edu!news.drenet.dnd.ca!crc-news.doc.ca!nott!bcarh189.bnr.ca!nrchh45.rich.nt.com!ferret.ocunix.on.ca!resurrect
  2. From: andrew@tamarix.demon.co.uk (Andrew Josey)
  3. Newsgroups: comp.unix.unixware.misc,comp.answers,news.answers
  4. Subject: UnixWare Frequently Asked Questions (Developer)
  5. Supersedes: <DvyxIn.1zn@tamarix.demon.co.uk>
  6. Followup-To: comp.unix.unixware.misc
  7. Date: Sun, 22 Sep 1996 07:30:24 GMT
  8. Organization: Home.
  9. Lines: 2057
  10. Sender: news@tamarix.demon.co.uk
  11. Approved: news-answers-request@MIT.EDU
  12. Expires: Sun, 27 Oct 1996 00:00:00 GMT
  13. Message-ID: <R.Dy4I6o.zF@tamarix.demon.co.uk>
  14. NNTP-Posting-Host: localhost
  15. Summary: Answers to questions frequently asked about SCO's UnixWare SDK
  16. X-NNTP-Posting-Host: tamarix.demon.co.uk
  17. X-Newsreader: TIN [version 1.2 PL2]
  18. Xref: informatik.tu-muenchen.de comp.unix.unixware.misc:17534 comp.answers:21236 news.answers:82330
  19.  
  20. Reposting article removed by rogue canceller.
  21.  
  22. Archive-name: unix-faq/unixware/developer
  23. Posting-Frequency: monthly
  24. Last-modified: August 11, 1996
  25. Version: 2.09
  26.  
  27. UnixWare Frequently Asked Questions (Developer)
  28.  
  29. This is the Developer section of the UnixWare Frequently Asked Questions
  30. file maintained on the Internet for the Usenet newsgroup
  31. comp.unix.unixware.misc. Its maintainer is Andrew Josey
  32. (andrew@tamarix.demon.co.uk). Suggestions and contributions are always
  33. welcome.
  34.  
  35. This document and the other FAQ files may be found on the world wide web
  36. at  http://www.freebird.org/faq/
  37.  
  38. This document may also be obtained by anonymous ftp from the freebird
  39. archive at
  40.  
  41.    ftp.freebird.org:/unixware/freebird/hints/FAQ/overview 
  42.    ftp1.freebird.org:/pub/mirror/freebird/hints/FAQ/overview 
  43.    ftp2.freebird.org:/pub/unixware/freebird/hints/FAQ/overview 
  44.  
  45. Small print: This file is Copyright 1996 freebird.org. Permission is
  46. granted for copying for non-commercial use. Many proper names of
  47. companies and software mentioned in these files are trademarks of their
  48. respective owners. All views are those of the individual contributors
  49. and not of their employers.
  50.  
  51. This article is posted monthly around the middle of the month. For more
  52. information about the files which compose the total UnixWare FAQ, see
  53. the "FAQ Overview" file posted regularly on the Internet newsgroup
  54. comp.unix.unixware.misc.
  55.  
  56.  
  57. INTRODUCTION
  58.  
  59.  
  60. The Developer section covers aspects of the UnixWare 1.1.x and UnixWare 2.x
  61. SDK.  It also covers general concerns for anyone writing software for the
  62. UnixWare operating system.
  63.  
  64.  
  65. TABLE OF CONTENTS
  66.  
  67. D0) How do I get ahold of UnixWare Developer Support?
  68. D1) What does the UnixWare 1.1 SDK contain?
  69. D2) Is there a C++ compiler for UnixWare 1.1?
  70. D3) What does the UnixWare 2.0 SDK contain?
  71. D4) Where is the ccs package on UnixWare 2.0?
  72. D5) Where is the documentation for the UnixWare SDK?
  73. D6) What books are there on UnixWare programming?
  74. D7) Where are the man pages for the Standard C functions?
  75. D8) Are there alternative SDKs to the UnixWare SDK for developers?
  76. D9) How do I correctly use the UCB compatibility libraries?
  77. D10) In what library is <undefined symbol> defined?
  78. D11) In what library is regex() and regcmp() defined?
  79. D12) In what library is XmbTextListToTextProperty defined?
  80. D13) What libraries do I need to include for X applications?
  81. D14) What libraries do I need to include for socket applications?
  82. D15) How do I compile the sample Motif applications?
  83. D16) Why do I get memory errors while building applications?
  84. D17) I don't like the new Motif look and feel, How do I get the old one?
  85. D18) How come I keep on getting as_dup proc failures?
  86. D19) How do I get the C compiler to accept C++ style comments?
  87. D20) How do I increase the number of socket connections for my application?
  88. D21) How do I run debug on a SUID root program?
  89. D22) Why do I get Driver without "f" flag not supported?
  90. D23) Why can't I get my SUID root program to work?
  91. D24) Why do I get a symbol error in librpcsvc.a on UnixWare 1.1?
  92. D25) How do I get kdb output to go to a tty?
  93. D26) Why do I have this library dtruntime.so.1 on UnixWare 2?
  94. D27) I included all the necessary libraries, why do I still get unresolved 
  95.      symbols?
  96. D28) How come I can't get some Motif keyboard mappings to work?
  97. D29) Why do I get a bad Makefile from xmkmf on UnixWare 2.0?
  98. D30) How do I get cc to place object files in specific directories?
  99. D31) Why does the open() call block when I try opening the serial port device?
  100. D32) How do I compile tin?
  101. D33) How do I compile emacs?
  102. D34) How do I compile Perl 5.001?
  103. D35) Where can I get audio software for UnixWare ?
  104. D36) Where can I get the GNU debugger (gdb) for UnixWare 2?
  105. D37) How can I debug an application without the source code?
  106. D38) When I link I can 't find the syslog routines, what should I do?
  107. D39) When I link I can 't find the strcasecmp routine?
  108. D40) When I link I can 't find the alloca routine?
  109. D41) How do I make a pkgmk add-on package?
  110. D42) How to build binaries on UnixWare to run on other SVR4 systems such
  111.    as Solaris x86?
  112.  
  113.  
  114. Subject: D0) How do I get ahold of UnixWare Developer Support?
  115.  
  116. The SCO Developer programme can be reached on 1-800-SCO-UNIX in North America,
  117. for the UK and International customers call SCO on +44 1923 816344.
  118.  
  119. As a member of the developer programme you get 5 free technical support
  120. questions among other benefits - see http://www.sco.com/Developers
  121. for info on the Developer programmes.
  122.  
  123. Subject: D1) What does the UnixWare 1.1 SDK contain?
  124.  
  125. 1) C compiler
  126. 2) Enhanced Graphical debugger
  127. 3) Motif development tools (sorry, no GUI builder).
  128. 4) Network client/server developer tools {so what's new :-) }.
  129. 5) Online documentation through Fingertip Librarian.
  130. 6) Driver development tools including sample driver source.
  131. 7) Windowing Korn Shell
  132. 8) Software Packaging Tools
  133. 9) Kernel Debugger
  134.  
  135. Subject: D2) Is there a C++ compiler for UnixWare 1.1?
  136.  
  137. (Note the ordering information needs to be updated in the
  138. light of the transfer of the UnixWare business to SCO ,
  139. that information has been requested).
  140.  
  141. The C++ Compilation System 2.0 for UnixWare 1.1 is available for the
  142. suggested retail price of U.S. $99 in CD ROM and QIC-24 tape formats.
  143. To order in the U.S.  or Canada, call 1-800-457-1767 or fax (317)
  144. 364-8888.  Outside North America, call +31-55-384279 or fax
  145. +31-55-434455.
  146.  
  147. Subject: D3) What does the UnixWare 2.0 SDK contain?
  148.  
  149. 1) C++ compiler with templates (C compiler is part of the AS and PE)
  150. 2) Enhanced Graphical debugger
  151. 3) Motif development tools (sorry, no GUI builder).
  152. 4) Network client/server developer tools {so what's new :-) }.
  153. 5) Online documentation through Dynatext.
  154. 6) Driver development tools including sample driver source.
  155. 7) Integrated window development tools
  156. 8) Software Packaging Tools
  157. 9) Kernel Debugger
  158. 10) Enhanced performance tools and profilers
  159. 11) Multithreaded application development
  160.  
  161. Subject: D4) Where is the ccs package on UnixWare 2.0?
  162.  
  163. The ccs package is no longer a part of the UnixWare SDK, but instead has
  164. been included on the UnixWare AS and PE media.  This is to facilitate
  165. support for third- party SDKs and other software such as databases that
  166. need the C compiler present to function.  Even though this does give you
  167. the C compiler, it does not give you all the components of the SDK such
  168. as the debugger, include files, and miscellaneous static libraries.  So
  169. for a full development environment, an SDK is still considered
  170. essential.
  171.  
  172. Note that you need to install the ccs package from your AS or PE media prior to
  173. installing the SDK, or YOU WILL NOT be able to install the C++ compiler.
  174.  
  175. Subject: D5) Where is the documentation for the UnixWare SDK?
  176.  
  177. UnixWare 2.01 includes all the UnixWare SDK documentation and provides
  178. it through the online documentation system of UnixWare 2.01.  Printed
  179. versions of the SDK Documentation are available in English only from:
  180.  
  181. Hart Graphics for the Novell Fulfillment Department
  182. P.O. Box 141805
  183. Austin, TX, USA 78714-9783
  184.  
  185. Or courier to:
  186.  
  187. Hart Graphics for the Novell Fulfillment Department
  188. 3106 Longhorn Blvd.
  189. Austin, TX, USA 78758
  190.  
  191. Country        Voice                    FAX
  192. Australia      0014-800-128-411    0014-800-124-233
  193. Canada         1-800-366-3892      1-800-826-5399
  194. Singapore      800-1100-073        800-1100-088
  195. U.S.           1-800-336-3892      1-800-826-5399
  196. All others          U.S. Country Code   U.S. Country Code
  197.                +512/834-6905       +512/834-8901
  198.  
  199. Group 6   Basic Software Development    US$ 125.00
  200. Group 7   Networking Development   US$  95.00
  201. Group 8   Windowing Development    US$  95.00
  202. Group 9   C++ Development          US$  55.00
  203. Group 10  IHV Development (drivers)     US$ 115.00
  204. Group 11  OSAPI Reference               US$  95.00
  205. Group 12  NetWare Lib. Ref. for C       US$ 125.00
  206. Group 13  Motif Reference Manual        US$  75.00
  207. Group 14  Additional SDK Reference US$  75.00
  208.  
  209. Note:  These prices do not include Shipping & Handling, or Tax.
  210.  
  211. Subject: D6) What books are there on UnixWare programming?
  212.  
  213. No UNIX programmer should be caught without the Stevens books:
  214.  
  215.   Advanced Programming in the UNIX Environment
  216.   W. Richard Stevens
  217.   Addison-Wesley, 1992
  218.   ISBN 0-201-56317-7
  219.  
  220.   UNIX Network Programming
  221.   W. Richard Stevens
  222.   Prentice Hall, 1990
  223.   ISBN 0-13-949876-1
  224.  
  225. Donald Lewine's POSIX programming guide is also indispensable as a
  226. reference for "which standard defines what API?" kind of questions:
  227.  
  228.   POSIX Programmer's Guide
  229.   Donald Lewine
  230.   O'Reilly and Associates, Inc.
  231.   ISBN 0-937175-73-0
  232.  
  233.  
  234. Subject: D7) Where are the man pages for the Standard C functions?
  235.  
  236. UnixWare 1.1:
  237.  
  238. Kevin Brannen (kbrannen@metronet.com) has become UnixWare's "Master of
  239. Man Pages":
  240.  
  241. First, make sure you've gone thru the "Guide to Fixing Man".  (I've sent
  242. Martin a note asking him to talk to Andrew Josey about putting my "Guide
  243. to Fixing Man" on the mail-server there at novell.co.uk.)
  244.  
  245. Now do "apropos command" or "man -k command", you should see the
  246. topic to do a man on.  For example, "man strchr" returns:
  247.  
  248.    No manual entry for strchr.
  249.  
  250. So do "apropos strchr", which returns:
  251.  
  252.    string: strcat, strncat, strcmp, strncmp, strcpy,  strncpy, strdup,
  253.    strlen,  strchr, strrchr, strpbrk, strspn, strcspn, strtok,
  254.    strstr (3C) -  string operations
  255.  
  256. which tells you that you should do "man 3c string".  Famous groupings
  257. that hide a lot of functions but which have no corresponding function are:
  258. string, memory, directory, trig, and exec.
  259.  
  260.  
  261. UnixWare 2.0:
  262.  
  263. I just use the man -k command.
  264.  
  265.  
  266. Subject: D8) Are there alternative SDKs to the UnixWare SDK for developers?
  267.  
  268. Yes, there are many options, and the number is increasing.  The first
  269. option developers generally try is using the GNU gcc compiler and other
  270. GNU tools.  The GNU tools are available from several sources.  The first
  271. place to try is ftp.freebird.org or any of its mirror sites.  Here you can
  272. get packaged binaries.  The second is to get them from a CD-ROM
  273. distribution such as the Prime Time Freeware Tools and Toys for UnixWare
  274. or the Walnut Creek SVR4 (UnixWare) CD-ROM.  These CDs include many
  275. useful utilities that any developer would find handy.  The third is to
  276. get source from the Free Software Foundation or any of the many CD-ROMs
  277. and build the binaries yourself.
  278.  
  279. Scott Raney <raney@metacard.com> writes:
  280.  
  281. MetaCard is a complete GUI development environment that includes a
  282. graphical interface builder and a high-performance VHLL (Very High
  283. Level Language).  With MetaCard both novice and professional
  284. developers can build graphical applications more rapidly than is
  285. possible with other tools.  Email info@metacard.com or see
  286. http://www.metacard.com for more information.
  287.  
  288. There are many third party compilers available for UnixWare, and if the
  289. vendors contact me I will include them in the FAQ.
  290.  
  291. Subject: D9) How do I correctly use the UCB compatibility libraries?
  292.  
  293. There are two problems that are typically encountered when
  294. compiling/linking code that uses Berkley-isms:
  295.  
  296. * Undefined symbols at link time
  297. * Incompatibilities between the SysV header files and the UCB libraries
  298.  
  299. C code using Berkley-isms such as index/rindex will generate "undefined
  300. symbol" messages for each of the BSD-specific functions.  To get around
  301. this, you have one of two options:
  302.  
  303. * Option A: Straight UCB compile
  304.    
  305.    Compile with the "UCB" compiler (/usr/ucb/cc).  This is actually a shell
  306.    script wrapper around the standard C compiler (/usr/ccs/bin/cc) that 
  307.    sets up the necessary #include and library paths.  This is the path to
  308.    take if you want a more "pure" BSD environment for your development.
  309.  
  310. * Option B: SysV compile with Berkeley extensions
  311.    
  312.    If you want a SysV environment, but need to link in some functions
  313.    only available in the BSD library (eg, you'll replace gethostname() with
  314.    uname() later), simply link in the UCB libraries _after_ the standard
  315.    (SysV) libraries.  For example:
  316.  
  317.      cc -o foo foo.c -lc -L /usr/ucblib -lucb
  318.  
  319. Note the order of the library specifications, and that "-lc" should
  320. precede the UCB library specification to resolve all possible synonyms
  321. against the SysV library, rather than the BSD library.
  322.  
  323. Be careful exercising option (b), however.  Merely linking against the
  324. UCB library, without the preceding "-lc", will cause code to be compiled
  325. against the SysV #include files (located in /usr/include) and then
  326. linked against the UCB libraries:
  327.  
  328.     cc -o foo foo.c -L /usr/ucblib -lucb  # Don't do this
  329.  
  330. (Note that an implicit "-lc" is appended to the command line.)
  331. Differences in such things as structure sizes between the SysV #includes
  332. and the UCB libraries can wreak all kinds of havoc - as Jim Vlcek
  333. discovered in just this fashion when trying to use setjmp in a source
  334. module that also called some UCB functions.  One way to get around this
  335. is to insert a "-I /usr/ucbinclude" directive into the command line, but
  336. this is essentially the effect of using /usr/ucb/cc.
  337.  
  338.  
  339. Gordon W. Ross <gwr@mc.com> wrote:
  340.  
  341.   I just wanted to mention here that most people I have helped with
  342.   porting problems related to the dirent or directory libraries have
  343.   caused their own problems by incorrectly using the UCB library.
  344.   The directory(3) routines in the UCB library only work with the
  345.   header files in /usr/ucbinclude so if you fail to put that in
  346.   your include path and just link with -lucb you end up with
  347.   seriously broken programs.  The stuff in /usr/ucbinclude/ and
  348.   /usr/ucblib/ was meant to be used by /usr/ucb/cc only, and
  349.   when used that way it (mostly) works.  I have usually found it
  350.   easiest to just stay away from the UCB library entirely.
  351.   I would advise others to do the same.  (The UCB library has
  352.   well known problems in signal and some dbm functions.)
  353.  
  354. Robert Withrow (witr@rwwa.com) wrote:
  355.  
  356.   In addition, checking the following things will almost always yield a
  357.   working port for any reasonably `well behaved program':
  358.  
  359.   1 Replace bcopy et.al with the apropriate memcpy functions...
  360.  
  361.   #define bcopy(b1,b2,len) memmove((b2), (b1), (size_t)(len))
  362.   #define bzero(b,len) memset((b), 0, (size_t)(len))
  363.   #define bcmp(b1,b2,len) memcmp((b1), (b2), (size_t)(len))
  364.  
  365.   2 Replace index and rindex approprately:
  366.  
  367.   #define index(a,b) strchr((a),(b))
  368.   #define rindex(a,b) strrchr((a),(b))
  369.  
  370.   3 Don't use the SVR4 library's signal() routine,
  371.   [use sigaction instead ...]
  372.  
  373.   /* Reliable signals */
  374.   /* This was taken from Stevens... */
  375.  
  376.   #include <signal.h>
  377.  
  378.   typedef void Sigfunc(int);
  379.  
  380.   Sigfunc *signal(int signo, Sigfunc *func)
  381.   {
  382.     struct sigaction act, oact;
  383.  
  384.     act.sa_handler = func;
  385.     sigemptyset(&act.sa_mask);
  386.     act.sa_flags = 0;
  387.     if (signo != SIGALRM) {
  388.       act.sa_flags |= SA_ESTART;
  389.     }
  390.     if (sigaction(signo, &act, &oact) < 0)
  391.       return(SIG_ERR);
  392.     return(oact.sa_handler);
  393.   }
  394.  
  395.   4 Replace random with lrand
  396.  
  397.   #define random() lrand48()
  398.   #define srandom(seed) srand48((seed))
  399.  
  400.   5 Replace the bsd readdir code with the Posix code (requires changing an
  401.   include file and a declaration usually, but also perhaps a symbol with a 
  402.   strlen.)
  403.  
  404.   6 Replace wait3 and wait4 with posix wait code.  This is complicated
  405.   because some code *writes* into the values that posix only provides read 
  406.   access to.
  407.  
  408.  
  409. Rick Richardson (rick@digibd.com) wrote:
  410.  
  411.   Its much easier to port stuff than most people think.
  412.  
  413.   I've found that 99.99% of applications with BSDisms can be ported
  414.   by simply compiling normally, but linking with -lc -lucb.  This
  415.   resolves the SVR4 C library first, avoiding problems with dirent
  416.   and the like, but also lets you pick up any BSD-isms like
  417.   random(), index(), etc.
  418.  
  419.   Really, its painless.
  420.  
  421. Other advice for porting applications :
  422.  
  423. What to use instead of gethostname, getdtablesize, getpagesize?
  424.  
  425. (a) gethostname
  426.  
  427. This can be replaced by using the sysinfo(2) routine.
  428.  
  429. #include <sys/systeminfo.h>
  430.  
  431.         ....
  432.  
  433.         char buf[MAXHOSTNAME];
  434.  
  435. /* BSD code was: */
  436. /* if (gethostname(buf, sizeof(buf)) < 0) { */
  437.  
  438. if (sysinfo (SI_HOSTNAME, buf, sizeof(buf)) < 0) {
  439.         perror("SI_HOSTNAME);
  440.         exit(ERROR);
  441. }
  442.  
  443. (b) getdtablesize
  444.  
  445. This can be replaced by the sysconf(2) routine
  446.  
  447. #include <unistd.h>
  448.  
  449.         ....
  450.         long tablesize;
  451.  
  452. #ifdef _SC_OPEN_MAX    /* POSIX define*/
  453.         tablesize = sysconf (_SC_OPEN_MAX);
  454. #else /* BSD code */
  455.         tablesize = getdtablesize();
  456. #endif
  457.  
  458. (c)  getpagesize
  459.  
  460. This can be replaced with a call to sysconf(2)
  461.  
  462. #include <unistd.h>
  463.  
  464.         ....
  465.         long pagesize;
  466.  
  467. #ifdef _SC_PAGE_SIZE    /* X/Open define*/
  468.         pagesize = sysconf (_SC_PAGE_SIZE);
  469. #else /* BSD code */
  470.         pagesize = getpagesize();
  471. #endif
  472.  
  473.  
  474.  
  475.  
  476. Subject: D10) In what library is <undefined symbol> defined?
  477.  
  478. The command 'nm' can be used to examine the contents of library files,
  479. or use the following script to automate the process.
  480.  
  481. --- Cut here and save to "who_defines", then "chmod +x who_defines"---
  482. #!/bin/sh
  483. if [ $# -ne 1 ]
  484. then
  485.         echo "Usage: who_defines function_name" >&2
  486.         exit 1
  487. fi
  488.  
  489. # You may need to add library directories to this list.
  490.  
  491. LIBDIRS="
  492.         /usr/lib
  493.         /usr/ccs/lib
  494.         /usr/X/lib
  495.         /usr/ucblib"
  496.  
  497. for dir in $LIBDIRS
  498. do
  499.         for lib in $dir/*.a $dir/*.so
  500.         do
  501.                 if [ -r "$lib" ]
  502.                 then 
  503.                         nm -px $lib | sed -n '/T \<'$1'\>/p' 2>/dev/null |
  504.                         while read ans
  505.                         do
  506.                                 echo $lib:$ans
  507.                         done
  508.                 fi
  509.         done
  510. done
  511. --- End of "who_defines" ---
  512.  
  513.  
  514. To determine where a symbol (eg, bind) is defined:
  515.  
  516.   % who_defines bind
  517.   /usr/lib/libsocket.a:0x000000c0 T bind
  518.   /usr/lib/libsocket.so:0x00008050 T bind
  519.  
  520. Note that, as above, you will often get multiple answers.  Here, we see
  521. that bind itself is in the socket directory (the .a and .so are the
  522. static and dynamic libraries, respectively).  The library name is the
  523. path that precedes the colon; your ld command line should thus include
  524. the entry:
  525.  
  526.   -lsocket
  527.  
  528.  
  529. Subject: D11) In what library is regex() and regcmp() defined?
  530.  
  531. The functions regex() and regcmp() are located in the general function library
  532. /usr/ccs/lib/libgen.a and can be included by using the option -lgen to cc.
  533.  
  534. Subject: D12) In what library is XmbTextListToTextProperty defined?
  535.  
  536. This function as well (as the function XmbTextPropertyToTextList()) is
  537. defined in the library /usr/X/lib/libXIM.so on UnixWare 1.1.  This
  538. should not be a problem on UnixWare 2.0.
  539.  
  540. Subject: D13) What libraries do I need to include for X applications?
  541.  
  542. This is how the sample application periodic was linked:
  543.  
  544. $ cc -o periodic periodic.o -O -Xa  -T 0x8300000 -L//usr/X/lib
  545. /usr/X/lib/libMrm.so /usr/X/lib/libXm.so -lXt -lXext -lX11  -lgen  -lnsl
  546. -z nodefs
  547.  
  548.  
  549. Subject: D14) What libraries do I need to include for socket applications?
  550.  
  551. Socket applications need to include the sockets library and the
  552. networking support library:
  553.  
  554. $ cc -o foo foo.c -lsocket -lnsl
  555.  
  556. Subject: D15) How do I compile the sample Motif applications?
  557.  
  558. The simple way to compile one of the sample Motif applications is to
  559. first copy it to some local working directory to avoid permission errors
  560. on the files:
  561.  
  562. $ cp -r /usr/X/lib/motifdemos/periodic periodic
  563.  
  564. Then cd into the periodic directory:
  565.  
  566. $ cd periodic
  567.  
  568. Run xmkmf to convert the Imakefile into a Makefile (See D29 first):
  569.  
  570. $ xmkmf
  571. imake -DUseInstalled -I/usr/X/lib/config
  572.  
  573. Then run make:
  574.  
  575. $ make
  576.         /bin/rm -f periodic.o
  577.         cc -c -O -Xa -I. -I./X11 -I./X11 -I///usr/X/include -I///usr/X/include/X11
  578. -I/usr/include -I//usr/X/include -I. -DSVR4 -DSYSV386 -DI18N
  579. -DFUNCPROTO=15 -DNARROWPROTO -DLIBDIR=\"/usr/X/lib\"
  580. -DDESTDIR=\"/usr/X\"  periodic.c
  581.         /bin/rm -f periodic
  582.         cc -o periodic periodic.o -O -Xa  -T 0x8300000 -L//usr/X/lib 
  583. /usr/X/lib/libMrm.so /usr/X/lib/libXm.so -lXt -lXext -lX11  -lgen  -lnsl  -z nodefs
  584.  
  585. Then run:
  586.  
  587. $ ./periodic
  588.  
  589. Subject: D16) Why do I get memory errors while building applications?
  590.  
  591. The first potential problem is running into user process limits which
  592. are controlled by the following tunables:.
  593.  
  594.      SDATLIM
  595.      HDATLIM
  596.      SSTKLIM
  597.      HSTKLIM
  598.      SVMMLIM
  599.      HVMMLIM
  600.  
  601. These may need to be increased so that enough memory resources are available to
  602. build very large applications.
  603.  
  604. The second potential problem could be a lack of swap space.  This can be
  605. checked by using the swap command.  Remember that swap is a dynamic
  606. thing so just running the swap command after a failed compile does not
  607. tell the story of what is happening during the compile.  On UnixWare 2,
  608. you can use the real time performance monitor (rtpm) or the GUI System
  609. Monitor to watch what is going on.  More swap can be added by swapping
  610. to a file which should be covered in the administration FAQ.
  611.  
  612. On UnixWare 2.0, there is also the possibility that you are running out
  613. of /tmp file space since this defaults to a memfs.  Since the compiler
  614. heavily uses /tmp, this filesystem may need to be increased by editing
  615. the /etc/vfstab file entry for /tmp, or not using a memfs for /tmp at
  616. all.
  617.  
  618. Subject: D17) I don't like the new Motif look and feel, How do I get the old
  619. one?
  620.  
  621. Some developers have expressed the desire to have Motif version 1.2.3
  622. under UnixWare 2.0 have the older look and feel of Motif version 1.2.2. 
  623. Following is a developers note:
  624.  
  625. > ... the look and feel of the XmToggleButton
  626. > is vastly different under UW 2.0 than those of the standard
  627. > Motif version.  The XmToggleButton in radio mode is a round
  628. > circle instead of the standard diamond shape.  The non-radio
  629. > mode XmToggleButton displays a check mark inside the square
  630. > under UW 2.0.  IMHO this is ugly.
  631.  
  632. This is the standard look and feel for CDE. Sun, HP, IBM, DEC, Novell,
  633. Fujitsu, Hitachi, and other vendors are or will soon be shipping this
  634. same Motif (same source code). While UnixWare 2.0 does not include the
  635. CDE desktop, it does include the CDE Motif implementation.
  636.  
  637. Furthermore, this user interface design change was in response to
  638. _significant_ user complaints about the old look. Hundreds of users have
  639. complained that the old visuals were not visibly distinctive, leaving
  640. them unsure which toggles were set and which were not. The new visuals
  641. are decidedly better, in the humble opinion of customers, user interface
  642. designers, and the vendors shipping CDE.
  643.  
  644. > The question I have is
  645. > WHY OH WHY did Novell do this type of thing?  The Motif look
  646. > and feel is supposed to be standard across all platforms.
  647. > What Novell did to Motif is gratuitous, and a disservice to
  648. > the efforts of a standard.
  649.  
  650. Nope, just the opposite. We participated in the standards activities
  651. that lead to this change.
  652.  
  653. In any case, one can get the old look (diamonds, no-checks) by setting
  654. these resources:
  655.  
  656. *enableToggleVisual: false    # use the diamond/empty-square visuals
  657. *enableToggleColor:  false    # use "select" color, instead of highlight color
  658.  
  659. This will restore the original, hard-to-distinguish visuals.
  660.  
  661. The complete set:
  662.  
  663. *enableToggleVisual:     {true|false}
  664.                # use the diamond/empty-square visuals
  665.  
  666. *enableToggleColor: {true|false}
  667.                # use "select" color, instead of highlight color for selected toggles
  668.  
  669. *enableBtn1Transfer:     {button2_transfer|true|false}
  670.                # true == Button 2 is ADJUST, Button 1 is TRANSFER
  671.                # button2_transfer, Button 2 is TRANSFER, Button 1 is drag
  672. and drop
  673.  
  674. *enableButtonTab:   {true|false}
  675.                # TAB moves among pushbuttons in tab groups, e.g.
  676. Apply/Reset/Cancel
  677.  
  678. *enableDefaultButton:    {true|false}
  679.                # shows button highlight inside the default-ring on the default
  680. button
  681.  
  682. *enableDragIcon:    {true|false}
  683.                # uses better default icons (visuals) for drag and drop
  684.  
  685. *enableEtchedInMenu:     {true|false}
  686.                # shows menu buttons as "pressed in" rather than "pushed out"
  687.  
  688. *enableMenuInCascade:    {true|false}
  689.                # can use the Button 3 to pull down menus on menu bars
  690.  
  691. *enableMultiKeyBindings:{true|false}
  692.                # enable use of additional key bindings (e.g. Sun's
  693. Cut/Copy/Paste)
  694.  
  695. In all cases, a value of "false" gets the original (old) Motif behavior.
  696. For UW 2.0, the default .Xdefaults file gives "true" for all these,
  697. except the third ("button2_transfer").
  698.  
  699. Subject: D18) How come I keep getting as_dup proc failures?
  700.  
  701. UnixWare 1.1:
  702.  
  703. These errors are generally caused by memory problems (as opposed to
  704. newproc pid_assign errors, which are generally due to low values of the
  705. NPROC and MAXUP tunables).  These errors could be caused by insufficient
  706. RAM, swap space or by processes which take up too much memory.
  707. Processes which do many time calls may be prone to the localtime memory
  708. leak and might get very large and thus take up a lot of memory.  Also,
  709. processes which do successive mallocs and frees may be prone to a
  710. problem with free (where memory does not get correctly returned to the
  711. system) and may also get very large and use too much memory.
  712.  
  713. To find whether there are processes running which have grown too large,
  714. enter:
  715.  
  716.     ls -l /proc
  717.  
  718. This will list all processes (by pid) and how much memory they take.
  719.  
  720. Aside from adding more RAM or swap, if there are processes which are
  721. taking up an inordinately large amount of memory, try applying PTF174
  722. (localtime memory leak) and/or PTF161 (problem with free).  These ptf's
  723. contain updates to shared object libraries and thus they should be able
  724. to be applied to the run-time system.  The app should not have to be
  725. re-compiled.
  726.  
  727. NOTE:  ptf174 is contained in Update 1.1.3.
  728.  
  729. UnixWare 2.0:
  730.  
  731. I have never heard of anyone getting this under UnixWare 2.0, but the
  732. same memory problems would be at fault.
  733.  
  734. Subject: D19) How do I get the C compiler to accept C++ style comments?
  735.  
  736. By supplying the following options on the cc command line, you can get
  737. cc to accept C++ style comments:
  738.  
  739.      cc -W0,-B foo.c
  740.  
  741. Subject: D20) How do I increase the number of socket connections for my
  742. application?
  743.  
  744. UnixWare 1.1:
  745.  
  746. To do this you first must edit the /etc/conf/sdevice.d/sockmod system
  747. file and increase the number in the third field.  Normally this defaults
  748. to 128.  The system maximum for this is about 256 connections due to a
  749. limitation in the library libc.so.  After this value has been increased,
  750. the kernel must be rebuilt and the system rebooted.  Also, the kernel
  751. tunable NUMTIM might need to be increased to allow for the greater
  752. number of streams modules required by the socket interface.  For every
  753. socket connection opened there is an associated file descriptor.  If the
  754. user executes the command 'ulimit -a' he/she will see that this defaults
  755. to 64.  In order to get more than 64 connections the associated tunables
  756. SFNOLIM and HFNOLIM must be increased.  Because of the limitations in
  757. the library libc that were described previously, there isn't much need
  758. to increase this beyond 256.  There is an upper limit to the number of
  759. connections allowed due to kernel memory allocation limitations.  Kernel
  760. memory must exist in the less than 16MB memory range due to
  761. historical/architectural reasons.  This means that the kernel image,
  762. drivers, and kernel buffers (including streams buffers) live in the less
  763. than 16MB memory range.  This creates the limitation on the number of
  764. connections based on how much memory can be acquired to maintain these
  765. connections.  This has implications for machines with less than 16 MB of
  766. RAM, i.e., more RAM may be necessary to increase the number of
  767. connections.  I was successful in getting 197 socket connections, and
  768. had a developer get around 230.
  769.  
  770. Now with the number of connections increased, if the applications being
  771. run are things such as telnet or ftp, the /etc/inet/inetd.conf
  772. configuration needs to be such that the required number of server
  773. daemons can be  started such as in.telnetd or in.ftpd.
  774.  
  775. Note: after the initial release of this TID, I have had some developers
  776. in Novell USG state that they believe there should not be a limitation
  777. in the number of connections through libc.  So it may be possible to
  778. increase this to a value greater than 256.
  779.  
  780. UnixWare 2.0:
  781.  
  782. There are several causes that lead to not having enough socket connections:
  783.  
  784. 1) The ulimit values may be limiting the number of open files allowed.
  785. 2) For UNIX Domain sockets, the third field in
  786. /etc/conf/sdevice.d/ticots is set too low.
  787.  
  788. 3) For Internet Domain sockets, the third field in
  789. /etc/conf/sdevice.d/tcp is set too low.
  790.  
  791. First, increase the number of open files a process is allowed to have by
  792. tuning the SFNOLIM system tunable.  This can be done using the System
  793. Tuner in the Admin_Tools folder on the desktop.  (This value can also be
  794. increased temporarily by typing "ulimit -n unlimited" as root.)
  795.  
  796. Second, for UNIX Domain sockets, increase the number in the third field
  797. of /etc/conf/sdevice.d/ticots.  Rebuild this module by typing "idbuild
  798. -M ticots".  For Internet Domain sockets, increase the number in the
  799. third field of /etc/conf/sdevice.d/tcp.  Rebuild this module by typing
  800. "idbuild -M tcp".
  801.  
  802. Reboot the system.
  803.  
  804. Note:  For this I increased the values to 1024, there appears to be no
  805. upper limit on how many connections there can be.
  806.  
  807. Subject: D21) How do I run debug on a SUID root program?
  808.  
  809. When trying to run debug on a setuid program, the following error
  810. message appears:
  811.  
  812.     System error attempting to control process <pid>
  813.     Create failed: all resulting processes killed
  814.  
  815. This happens whether debug is run by the program owner (usually root) or
  816. not.  debug cannot be run by someone other than the program owner
  817. (usually root) because then the person running the program could make
  818. modifications to the program which are not explicitly allowed by
  819. setuid.
  820.  
  821. The graphical version of debug cannot be run by the program owner
  822. (usually root) because this person is generally not the same person
  823. whose desktop debug will try to display on.  By default, X does not
  824. allow one user to display windows on another person's desktop.
  825.  
  826. To run the graphical version of debug on a setuid program:
  827.  
  828.     1)  xhost +
  829.  
  830. (This allows other users to display windows on your desktop).
  831.  
  832.     2)  su to the person who owns the setuid program.
  833.  
  834.     3)  run debug on the program.
  835.  
  836. Subject: D22) Why do I get Driver without "f" flag not supported?
  837.  
  838. This driver probably has a version 0 Master file and does not have an
  839. "f" in the characteristics field (see man (4) Master).  This means that
  840. this driver is not a DDI/DKI compliant driver, and thus will not work on
  841. UnixWare 2.0.
  842.  
  843. The solution is to modify the driver to be DDI/DKI compliant.  This will
  844. also guarantee that the driver will work on future releases of UnixWare.
  845. Consult the Device Driver Reference Manual (DDI/DKI) in the Dynatext
  846. Browser.  It gives good detail on what is needed to be compliant, what
  847. is supported, and what is not supported.
  848.  
  849. NOTE:  We stated that UnixWare 1.1 drivers will run on UnixWare 2.0.
  850. The actual situation is that DDI/DKI compliant 1.1 drivers (drivers
  851. written for 1.1) will work on 2.0.  The problem is that 1.1 supported a
  852. lot of older driver interfaces, but this support is not in 2.0.
  853. Developers need to become DDI/DKI compliant.
  854.  
  855. Subject: D23) Why can't I get my SUID root program to work?
  856.  
  857. The common situation is that a developer has a SUID application (The
  858. effective user ID bit set) for a root owned application and it is unable
  859. to locate dynamic libraries at runtime.  The error would be something
  860. like:
  861.  
  862. dynamic linker : xapplication : error opening libX11.so
  863. Killed
  864.  
  865. This is common if the SUID root application is an X application.
  866.  
  867. This is a deliberate action to prevent a problem with security.  If the
  868. dynamic linker did not cause this to break on SUID programs a potential
  869. security hole would occur.  The security hole would be in the form that
  870. the SUID program would use the LD_LIBRARY_PATH to search for dynamic
  871. libraries needed.  In a SUID program that path must be static.  If the
  872. library were located using the LD_LIBRARY_PATH then a user could
  873. potentially create his own library that mimics a well known library. 
  874. This "imposter" library could have a deliberate security hole in it.
  875. When the application tried to locate a library such as libX11.so and
  876. went to the user's imposter library by using the LD_LIBRARY_PATH, the
  877. security would have been compromised since the application may be owned
  878. by root.
  879.  
  880. To prevent this security problem, SUID applications must have the path
  881. to all libraries statically included.  To do this the developer needs to
  882. set the LD_RUN_PATH to point to all libraries needed by that application
  883. prior to linking.  By default SUID applications search for libraries in
  884. /usr/lib, but if the application is an X application, all the X
  885. libraries are in /usr/X/lib and these libraries would not be located if
  886. the LD_RUN_PATH environment variable was not set prior to linking.
  887.  
  888. Subject: D24) Why do I get a symbol error in librpcsvc.a on UnixWare 1.1?
  889.  
  890. This library has a symbol table problem.  When trying to link to the library
  891. librpcsvc.a, the developer gets an error that this library is corrupt.
  892.  
  893. This library can be fixed by running the 'ar' command on it as root.
  894.  
  895. # ar -sr /usr/lib/librpcsvc.a
  896.  
  897. Subject: D25) How do I get kdb output to go to a tty?
  898.  
  899. The kdb command 'newterm' will let you change a kdb session to a tty.
  900. All subsequent kdb sessions will then go to this same tty.  Just make
  901. sure there is a ttymon active on the tty before you do this.
  902.  
  903. The syntax on UnixWare 2.0 is "newterm <driver> <minor #>", so for
  904. example "newterm iasy 2" will send output to /dev/tty01.  For UnixWare
  905. 1.1 the syntax is a little different, but the effect is the same.
  906.  
  907. Another option which will force all console output to another device is
  908. to edit the /stand/boot file and use the console parameter to indicate
  909. another device.  See the man page for boot(4) for parameter details and
  910. the man page for boot(1) for information on the boot file itself.
  911.  
  912. Subject: D26) Why do I have the library dtruntime.so.1 on UnixWare 2?
  913.  
  914. Developers have noticed that several of the standard X libraries are
  915. symbolically linked to the library /usr/X/desktop/dtruntime.so.1.  What
  916. is the reasoning behind this?
  917.  
  918. The reason for this library is as follows:
  919.  
  920. 1)  dtruntime is a library that is the combination of many of the X libraries
  921.  
  922. 2)  This was done to speed up X programs.  It accomplishes this 2 ways:  the
  923.     run-time linker has to do much, much less work at startup to resolve
  924.     symbols and locality tuning is more effective on one large object (as
  925.     opposed to many small ones) since there is a high correlation between
  926.     references to multiple libraries (e.g. Xtfunc always calls Xfunc).
  927.  
  928. 3)  There is no wasted space on a run-time system (a system with no SDK). 
  929.     Simply, many libraries are link-edited to one and links are made to the
  930.     individual names.  On a system with the SDK installed, 3 MB is wasted,
  931.     since we can't link the run-time libraries to the build libraries (i.e. 
  932.     ZZZ.so.1 -> ZZZ.so).
  933.  
  934. 4)  Any programmer who uses the SDK will not see dtruntime unless he/she is
  935.     doing ls's around /usr/X (see #5).
  936.  
  937. 5)  One's binaries still say that the program requires libXt.so.5.0 to run. 
  938.     It just happens to be that on our system, this file is a link to
  939.     dtruntime.
  940.  
  941.     In fact, we took great effort in not "exposing the implementation"
  942.     so that executables will never be dependent on dtruntime and the ABI 
  943.     is not violated.
  944.  
  945. 6)  Some have commented "what a hack".  
  946.     
  947.     This is, actually, an unhack.  Novell realized that the illusion
  948.     of separate libraries was just that . . . so we put them together.  The
  949.     beauty of the idea is that we can unlink the libraries at any time if
  950.     there was a reason to do so (see #5).
  951.  
  952. Subject: D27) I included all the necessary libraries, why do I still get
  953. unresolved symbols?
  954.  
  955. Some developers have noticed that while linking an application on
  956. UnixWare with the correct libraries, they still get unresolved symbols. 
  957. The libraries are even verified with the 'nm' command to contain the
  958. needed symbols.
  959.  
  960. It has been noted that how files are specified on the cc command line
  961. affects what libraries are searched and included.
  962.  
  963. The following command line will not work:
  964.  
  965.         $ cc -lsocket -lnsl -lgen -o main.o main.c
  966.  
  967. Where this one will:
  968.  
  969.         $ cc -o main.o main.c -lsocket -lnsl -lgen
  970.  
  971. Note that the libraries must be specified last.  The reason for this is
  972. because the first few options go to the C compiler, where the last
  973. options go to the linker.  Before someone states that this is broke,
  974. this is actually done to be SVID/ABI compliant.
  975.  
  976. Subject: D28) Why can't I get some Motif keyboard mappings to work?
  977.  
  978. A Developer had an application that remapped keys on the keyboard in the
  979. defaults file located in /usr/X/lib/app-defaults under UnixWare 1.1.3
  980. and it worked fine.  When moved to UnixWare 2.01, the application can no
  981. longer map the keys correctly.
  982.  
  983. The problem here is that in going from UnixWare 1.x to UnixWare 2.x the
  984. Motif library changed from 1.1 to 1.2.  With this library change, the
  985. concept of Virtual Key bindings was introduced which adds a level of
  986. abstraction between actual Key events and what applications act on.
  987. Client side generated osfXXX key events are then translated to actual
  988. key events at the Server level.
  989.  
  990. When an application overloads Raw Key events, there's no guarantee that
  991. Motif will not overload those.
  992.  
  993. In a test program I was able to overload <Key>Home and <Key>End with no
  994. problem but could not overload <Key>Insert.  Changing the <Key>Insert to
  995. <Key>osfInsert worked fine. In general the application should overload
  996. the osfXXX events instead.
  997.  
  998. The developer needs to modify the translation table to overload
  999. <Key>osfInsert <Key>osfBeginLine and <Key>osfEndLine instead of the
  1000. <Key>Insert, <Key>Home and <Key>End translations.
  1001.  
  1002. Subject: D29) Why do I get a bad Makefile from xmkmf on UnixWare 2.01?
  1003.  
  1004. During the building of periodic in the /usr/X/lib/motifdemos/periodic
  1005. directory, I get these problems:
  1006.  
  1007. $ cd periodic
  1008. $ ls -l
  1009. total 130
  1010. -r--r--r--    1 darrend  other        984 Jun 22 10:50 Imakefile
  1011. -r--r--r--    1 darrend  other       1127 Jun 22 10:50 Periodic.ad
  1012. -r--r--r--    1 darrend  other      18137 Jun 22 10:50 periodic.c
  1013. -r--r--r--    1 darrend  other      35962 Jun 22 10:50 periodic.uil
  1014. -r--r--r--    1 darrend  other       7381 Jun 22 10:50 periodic_local.uil
  1015. $ xmkmf
  1016. imake -DUseInstalled -I/usr/X/lib/config
  1017. $ make
  1018.         /bin/rm -f periodic.o
  1019.         cc -c -O -Xa -I. -I./X11 -I./X11 -I///usr/X/include -I///usr/X/include/X
  1020. 11 -I/usr/include -I//usr/X/include -I. -DSVR4 -DSYSV386 -DI18N  
  1021. -DFUNCPROTO=15
  1022.  -DNARROWPROTO -DLIBDIR=\"/usr/X/lib\" -DDESTDIR=\"/usr/X\"  periodic.c
  1023.         /bin/rm -f periodic
  1024.         cc -o periodic periodic.o -O -Xa  -T 0x8300000 -L//usr/X/lib  ./lib/Mrm/
  1025. libMrm.so ./lib/Xm/libXm.so -lXt -lXext -lX11  -lgen  -lnsl  -z nodefs
  1026. UX:ld: ERROR: ./lib/Mrm/libMrm.so: fatal error: cannot open file for reading
  1027. *** Error code 1 (bu21)
  1028. UX:make: ERROR: fatal error.
  1029. $
  1030.  
  1031. It appears that the Motif templates file in /usr/X/lib/config is
  1032. incorrect.  You can get imake or xmkmf to work correctly if you fix the
  1033. file /usr/X/lib/config/Motif.tmpl with the following corrections.
  1034.  
  1035. Change:
  1036.     MTOOLKITSRC = $(LIBSRC)/Xt
  1037.      MWIDGETSRC = $(LIBSRC)/Xm
  1038.    MRESOURCESRC = $(LIBSRC)/Mrm
  1039.  
  1040. To:
  1041.     MTOOLKITSRC = /usr/X/lib
  1042.      MWIDGETSRC = /usr/X/lib
  1043.    MRESOURCESRC = /usr/X/lib
  1044.  
  1045. I suggest that you comment out the old lines like this:
  1046. /*    MTOOLKITSRC = $(LIBSRC)/Xt */
  1047. /*     MWIDGETSRC = $(LIBSRC)/Xm */
  1048. /*   MRESOURCESRC = $(LIBSRC)/Mrm */
  1049.  
  1050. Note also that you will get a permissions error if you try to build this
  1051. application in that directory.  I suggest making a local copy, as root
  1052. does not have the necessary environment for building this application
  1053. (No X references).
  1054.  
  1055. Subject: D30) How do I get cc to place object files in specific directories?
  1056.  
  1057.  
  1058. Developers using the C compiler cc need to place object files in
  1059. specific directories.  Note that this feature is supported by some third
  1060. party compilers, e.g.
  1061.  
  1062.         $ cc -c darren.c -o /tmp/darren.o
  1063.  
  1064. The SVID definition states that the -o option only applies to the
  1065. linker.  Since using the -c option means the linker is never called,
  1066. this option will not work.
  1067.  
  1068. There is a workaround using the -Wa option to the compiler (see the cc
  1069. man page.)
  1070.  
  1071.         $ cc -c darren.c -Wa,'-o/tmp/darren.o'
  1072.  
  1073.  
  1074. Note that I did not put a space after the -o option.
  1075.  
  1076. Subject: D31) Why does the open() call block when I try opening the serial port
  1077. device?
  1078.  
  1079. The general symptoms of this problem are:
  1080.  
  1081. 1) I try to open the serial port device and the open() call blocks.
  1082.  
  1083. 2) How can I bypass this insistence on having a modem carrier when I am not
  1084. talking to a modem?
  1085.  
  1086. 3) I don't want O_NOBLOCK behavior for my serial device.
  1087.  
  1088.  
  1089. One solution involves making a special serial cable as follows:
  1090.  
  1091.     You could loop 6, 8 and 20 at the Unix end to assert DCD.
  1092.  
  1093.  
  1094. Another solution involves opening the driver non-blocking.  There is an
  1095. O_NDELAY flag or an O_NOBLOCK flag to open() which causes the open call
  1096. to succeed without waiting for carrier detect to be asserted. If you use
  1097. either of these modes,  you can turn off the non blocking behavior,
  1098. since this is not the operating mode you may desire for the subsequent
  1099. read() and write() calls.
  1100.  
  1101. You use fcntl() after open() to turn off O_NDELAY (error checks omitted):
  1102.  
  1103.     fd = open ( "/dev/tty01h", O_RDWR | O_NDELAY );
  1104.     flags = fcntl ( fd, F_GETFL );
  1105.     fcntl ( fd, F_SETFL, flags & ~O_NDELAY );
  1106.  
  1107.  
  1108. Subject: D32) How do I compile tin?
  1109.  
  1110. This should by now be a classic problem in compiling tin under UnixWare
  1111. (1.0 at least, I don't know if 1.1 fixed this particular bug).
  1112.  
  1113. When you're compiling tin, the make may fail on the first source file
  1114. with messages like the following:
  1115.  
  1116. "/usr/include/sys/termios.h", line 503: (struct) tag redeclared: winsize
  1117. active.c, line 615: warning: argument is incompatible with prototype: arg #4
  1118. active.c, line 616: warning: argument is incompatible with prototype: arg #4
  1119. make: fatal error.
  1120.  
  1121. If this occurs, you've encountered a bug in one of the UnixWare system
  1122. header files.  You can do one of two things to compile tin under
  1123. UnixWare:
  1124.  
  1125. * Fix the header file.  Change all occurrences of
  1126.  
  1127.     _IO_PT_PTEM_H
  1128.  
  1129.    to
  1130.  
  1131.     _IO_PTEM_H
  1132.  
  1133.    in the file /usr/include/sys/ptem.h.
  1134.  
  1135. <or>
  1136.  
  1137. * Hack the tin header file tin.h, which is what I did.  At line 130 in 
  1138.    tin.h, you'll find two #include directives, <sys/ptem.h> and 
  1139.    <sys/tty.h>.  Place the following #define between these two #includes:
  1140.  
  1141.     #define _IO_PTEM_H
  1142.  
  1143. This works around the problem with the system header files, if you're
  1144. not excited about modifying them (or don't have su privileges).
  1145.  
  1146.  
  1147. Subject: D33) How do I compile emacs?
  1148.  
  1149. The UnixWare cc preprocessor (cc -P) doesn't work the same as
  1150. /usr/ccs/bin/cpp from the configure script.  You have three options:
  1151.  
  1152. 1) Use gcc.  The GNU compiler groks the GNU configure file.
  1153.  
  1154. 2) Use the UnixWare preprocessor /usr/ccs/bin/cpp directly.
  1155.  
  1156. 3) Get the emacs binary as indicated in the FAQ.
  1157.  
  1158. Subject: D34) How do I compile Perl 5.001?
  1159.  
  1160. Note that Perl 5.001 source and binaries are now available from ftp.abs.net
  1161.  
  1162. tye@fohnix.metronet.com (Tye McQueen) wrote:
  1163.  
  1164.    Porting (aka Installing) Perl 5.x to UnixWare systems can be
  1165.    confusing, but it need not be difficult.  Here are some notes
  1166.    to help you.  I hope to make some of these notes obsolete in a
  1167.    future release of Perl and to include the remaining ones in a
  1168.    README.svr4 file in that distribution.
  1169.  
  1170.    First, be sure you have Perl5.001m or later.  You can fetch a copy
  1171.    from:
  1172.      ftp://ftp.metronet.com/pub/perl/source/perl5.001m.tar.gz
  1173.     or many other places listed in the Perl meta-FAQ, which can be
  1174.     found at:
  1175.      http://www.khoros.unm.edu/staff/neilb/perl/metaFAQ/metaFAQ.html
  1176.     or
  1177.      ftp://ftp.khoros.unm.edu/pub/perl/metaFAQ.txt
  1178.    I don't recommend trying to apply patches to a Perl5.000 or
  1179.    Perl5.001 distribution; just fetch the full latest distribution.
  1180.  
  1181.    Next, an easy way to build Perl successfully is simply:
  1182.  
  1183.     1.  $ mv -f config.sh config.sh.old
  1184.     2.  $ ./Configure -dsE
  1185.     3. You can edit config.sh here (but don't do it this first time).
  1186.     4.  $ ./Configure -S
  1187.     5.  $ env LD_LIBRARY_PATH=`pwd` make
  1188.     6.  $ env LD_LIBRARY_PATH=`pwd` make test
  1189.     7. Become "root", if you aren't already.
  1190.     8.  # env LD_LIBRARY_PATH=`pwd` make install
  1191.     9. Answer "yes" that you want /usr/bin/perl set up.
  1192.  
  1193.    I say "simply" because this method only asks you one question and I've
  1194.    told you what the answer is.  Yes, it is more steps than it should be.
  1195.  
  1196.    You might want to save the last two steps until you are sure you
  1197.    have everything configured the way you like.  Please don't let the
  1198.    "WHOA THERE!!!"s scare you.  They are there for a reason and the
  1199.    default answer ("yes") is what you want.
  1200.  
  1201. More advanced options
  1202.  
  1203.    If you don't like the directories that Configure picks to install
  1204.    things into, the simplest change is to add "-Dprefix=/usr/local" on
  1205.    the end of Step 2 above (where "/usr/local" is the directory where
  1206.    you want "bin/*", "lib/perl5/...", and possibly "man/*/*" to be
  1207.    installed).  ./Configure will pick /usr/local if it exists,
  1208.    otherwise it will probably pick /opt.
  1209.  
  1210.    You can also go back to Step 3 above and change the paths in config.sh
  1211.    that you don't like (the Notes section has more hints on doing this).
  1212.  
  1213.    There are even more options you can give to Configure to influence
  1214.    what directories it picks, but I haven't tested those options so I
  1215.    won't go into those switches here.  You can type "./Configure -h" for
  1216.    more information on switches that can be given to Configure.
  1217.  
  1218.    If you want to use GNU CC to build Perl:
  1219.  
  1220.      * Add "-Dcc=gcc" on the end of Step 2 above.
  1221.      * Be sure to not use GNU AS, GNU LD, nor GNU LIBC.
  1222.      * Make sure you installed GNU CC correctly, including the
  1223.        "fix-includes" step.
  1224.      * You may be able to use GNU's gdbm to emulate odbm and ndbm for the
  1225.        ODBM_File and NDBM_File extensions, but I've seen reports of
  1226.        problems (lock ups) with this under Linux.
  1227.  
  1228.    I haven't installed gcc so I haven't tested this (these hints come
  1229.    from problems others have had using GCC on other systems).
  1230.  
  1231. Possible problems
  1232.  
  1233.   Building Perl on UnixWare 1.x then running on UnixWare 2.x
  1234.  
  1235.    The most serious problem I am aware of is that a Perl executable
  1236.    compiled on UnixWare 1.x may run on UnixWare 2.x but it will not
  1237.    do I/O correctly.  This is because Perl uses some "officially
  1238.    non-standard" optimizations (that happen to port well to a wide
  1239.    variety of UNIX systems) in order to get much faster I/O under many
  1240.    circumstances.
  1241.  
  1242.    If you really want one version of Perl that will run on both UnixWare
  1243.    1.x and UnixWare 2.x, then you can disable these optimizations either
  1244.    by adding "-Dd_stdiobase=undef" on the end of Step 2 above or by
  1245.    going back to Step 3 above and changing d_stdiobase='define' to
  1246.    d_stdiobase='undef' then continuing on with the rest of the steps.  I
  1247.    have tested both of these methods and am using such a version of Perl
  1248.    under both UnixWare 1.1 and UnixWare 2.01.
  1249.  
  1250.    If I don't find any problems with it I will update the hints/svr4.sh
  1251.    file to do this automatically for UnixWare systems.  I'll also see if
  1252.    Novell or SCO will make this version available in "pkgadd" format.
  1253.  
  1254.   File glob tests fail due to broken csh in UnixWare 1.1.4.
  1255.  
  1256.    I have two reports that the version of csh included with UnixWare 1.1.4
  1257.    is broken (which is the version of csh included in PTF2001 which fixes
  1258.    memory leaks in csh).  This will cause some of the "file glob" tests to
  1259.    fail.
  1260.  
  1261.    If this happens to you, you can get around the problem by going back
  1262.    to Step 3 above and changing d_csh='define' to d_csh='undef' in
  1263.    config.sh then continuing on with the remaining steps.  You might also
  1264.    want to check out my File::Glob module which does file globbing inside
  1265.    Perl (http://www.metronet.com/~tye/glob.html).
  1266.  
  1267.   Easy to break DynaLoader, ODBM_File, and NDBM_File.
  1268.  
  1269.    You should be able to include Dynamic Loading along with both the
  1270.    ODBM_File and NDBM_File extensions in Perl under SVR4.  It is very easy
  1271.    to run into problems using any of these three features under SVR4, but
  1272.    if you follow the above instructions, then you shouldn't run into
  1273.    these problems.
  1274.  
  1275.    You won't get the ODBM_File nor NDBM_File extensions if you haven't
  1276.    installed the "BSD Compatibility" package.  This is because the dbm
  1277.    routines are kept in /usr/ucblib/libucb.a and the ndbm routines are
  1278.    kept in /usr/ucblib/libdbm.a and require /usr/ucblib/libucb.a.
  1279.  
  1280.    This stuff is easy to break because all SVR4 systems (except UnixWare
  1281.    2.x -- thanks Novell!) have a broken /usr/ucblib/libucb.a which will
  1282.    often break programs that try to use it.  The hints/svr4.sh file can
  1283.    usually prevent problems by telling Perl to not use most of the
  1284.    routines in libucb.a.  The way hints/svr4.sh does this is why Configure
  1285.    gives you all of those scary "WHOA THERE!!!" warnings.
  1286.  
  1287.    You can use most (on UnixWare 2.x, all) of the BSD-compatibility
  1288.    routines, if you want.  I made the defaults to not use any of these
  1289.    for several reasons.
  1290.  
  1291.      * Prior to UnixWare 2.x, trying to ld with the floating point
  1292.        routines from libucb.a (ecvt, gcvt, fcvt, etc.) resulted in
  1293.        "undefined symbol" errors.  If using them only in a dynamically
  1294.        loaded extension, then these "unresolved external" errors might
  1295.        not show up until you tried to use the extension.
  1296.      * I worried that there could be SVR4.x systems with versions of
  1297.        libucb.a where even more of these routines don't work.
  1298.      * I don't believe that they add any functionality over the
  1299.        corresponding native SVR4.x routines, even considering how Perl
  1300.        knows how to use them.  If anyone finds otherwise, please let us or
  1301.        me know so that Perl can be fixed to use the SVR4.x routines more
  1302.        effectively.
  1303.      * I worry that they add some overhead, though probably not a great
  1304.        amount.
  1305.  
  1306. Notes
  1307.  
  1308.   Changing where Perl will be installed
  1309.  
  1310.    Don't worry too much about all the stuff in config.sh that may not
  1311.    make sense to you.  You can just change the first part of any absolute
  1312.    paths (those that start with "/") that appear between single quotes
  1313.    (') after an equal sign (=).  But don't change any of these "paths"
  1314.    that point to files that already exist on your system (ie. only change
  1315.    ones that point either to directories or to places that don't exist
  1316.    yet).  Save a copy of config.sh before you edit it in case you change
  1317.    your mind.
  1318.  
  1319.  
  1320. Subject D35) Where can I get audio software for UnixWare ?
  1321.  
  1322. Voxware driver support for UnixWare 1.x and 2.x can
  1323. be found on ftp.abs.net:/unixware/freebird/sound.
  1324.  
  1325.  
  1326. Subject D36) Where can I get the GNU debugger (gdb) for UnixWare 2?
  1327.  
  1328. This can be found in the developer section of the freebird
  1329. archive. Check ftp://ftp.freebird.org/unixware/developer.
  1330.  
  1331.  
  1332. Subject: D37) How can I debug an application without the source code?
  1333.  
  1334. Peter Lord writes:
  1335.  
  1336. If you are a developer working on a new software product, then debugging
  1337. an application is fairly straight forward. But what can you do if you
  1338. are an end user and don't have access to the source code?
  1339.  
  1340. You may come across this problem when trying to run an application
  1341. designed for a different operating system on UnixWare.
  1342.  
  1343. Truss
  1344.  
  1345. Truss(1) is a wonderful program designed for debugging BINARY programs.
  1346. It takes control of the process you are interested and prints out all
  1347. the system calls your program makes!
  1348.  
  1349. For example, if you tried to run the SCO version of Framemaker 3.1X on
  1350. UnixWare, you will find it fails without any sensible error message. By
  1351. trussing the Framemaker binaries, you can find out if any of the system
  1352. calls are failing. In this example, it was easy to find out that
  1353. Framemaker was trying to run a program from the bin.i386 directory ...
  1354. but only a bin.scounix directory existed. A simple symbolic link brought
  1355. the application into life!
  1356.  
  1357. Lets take a simple example. 
  1358.  
  1359. $ ls /fred
  1360. UX:ls: ERROR: Cannot access /fred: No such file or directory
  1361. $
  1362.  
  1363. In this case we get a error message which can be understood ... but this
  1364. may not always be the case. Now, if we truss this same command we get :-
  1365.  
  1366. $ truss -o/tmp/trussout ls /fred
  1367. UX:ls: ERROR: Cannot access /fred: No such file or directory
  1368. $
  1369.  
  1370. and the file /tmp/trussout contains :- 
  1371.  
  1372. ....
  1373. lxstat(2, "/fred", 0x08047520)                  Err#2  ENOENT
  1374. ....
  1375. write(2, " U X : l s :  ", 7)                   = 7
  1376. write(2, " E R R O R", 5)                       = 5
  1377. write(2, " :  ", 2)                             = 2
  1378. write(2, " C a n n o t   a c c e s".., 47)      = 47
  1379. _exit(2)
  1380.  
  1381. Here you can see that ls has made a system call lxstat which returns an
  1382. error.
  1383.  
  1384. So you can see that although truss cannot follow all of the program, it
  1385. can print out the system calls and so give you some clues to where your
  1386. program is failing.
  1387.  
  1388. One useful truss option is -t. This allows tracing of certain system
  1389. calls only (and thus reducing the amount of output you need to scan
  1390. through). See the truss manual page for more options.
  1391.  
  1392. Truss can even follow processes which are currently running! For
  1393. example, if you want to debug your running lockd daemon, use ps to find
  1394. out it's process id and then use the command truss -p pid. 
  1395.  
  1396. Subject: D38) When I link I can 't find the syslog routines, what should I do?
  1397.  
  1398. You need to include libgen. Add -lgen to your link line.
  1399.  
  1400. Subject: D39) When I link I can 't find the strcasecmp routine?
  1401.  
  1402. You need to link to the ucblib library. This has to be done
  1403. as follows:
  1404.         -lc -L/usr/ucblib -lucb
  1405.  
  1406. Alternately just extract the object file (stricmp.o) from /usr/ucblib/libucb.a
  1407. and link that to your executable:
  1408.  
  1409. $ cd /tmp
  1410. $ ar x /usr/ucblib/libucb.a stricmp.o  
  1411.  
  1412. Subject: D40) When I link I can 't find the alloca routine?
  1413.  
  1414. See D38 above.
  1415.  
  1416. Subject: D41) How do I make a pkgmk add-on package?
  1417.  
  1418. UnixWare supports the SVR4 packaging tools and the pgmk(1) utility
  1419. to create a package.  If you cannot find the packaging tool that you need , 
  1420. check that you have the  Software Packaging Tools (softint) package
  1421. installed from the SDK (or ask SCO to make a PTF - since they
  1422. tools really ought to be available to all developers)
  1423.  
  1424. These three tools are in the Base 
  1425.  
  1426. /usr/bin/pkginfo - display software package information
  1427. /usr/bin/pkgparam - display package parameter values
  1428. /usr/bin/pkgtrans - translate package format
  1429.  
  1430. The key scripts for creating packages are in the SDK softint package:
  1431.  
  1432. /usr/bin/pkgmk - create a package
  1433. /usr/bin/pkgproto - generate a package prototype file
  1434.  
  1435. For further details refer to the  Software Tools Book in Dynatext, Chapter 8,
  1436. or the UNIX SVR4 Programmer's Guide: System Services
  1437. and Application Packaging Tools Manual. The Generic Application Binary
  1438. Interface (gABI) specification is also a good reference for this material.
  1439.  
  1440. This will allow the system to track all installed software thus
  1441. ensuring its integrity.
  1442.  
  1443. Its good practice for applications to only install or create files in 
  1444. designated places within the file tree away from the system
  1445. files if possible. A possible scenario is noted below. 
  1446.  
  1447.                         root or "/"
  1448.                         /    |    \   \
  1449.                        /     |     \   \
  1450.                      opt    usr    etc  var
  1451.                    / | \     |      |   /  \
  1452.                  bin man lib bin   opt opt  tmp
  1453.                         / \         / \
  1454.                       pkg1 pkgn   pkg1 pkgn
  1455.  
  1456. /opt, /var/opt and /etc/opt\f1 are reserved in the file
  1457. tree for the installation of application software packages. Each
  1458. add-on package should adhere to the following rules.
  1459. Static package objects should be installed in /opt/lib/pkg, where
  1460. pkg is the package abbreviation.
  1461.  
  1462. Package objects that change in normal operations (for example,
  1463. log and spool files) should be installed in /var/opt/pkg
  1464.  
  1465. Machine-specific configuration files should be installed in 
  1466. /etc/opt/pkg.
  1467.  
  1468. Executables that are directly invoked by users should be installed
  1469. in /opt/bin
  1470.  
  1471. Only package objects that must reside in specific locations within the
  1472. system file tree in order to function properly (for example,
  1473. special files in /dev) should be installed in those locations.
  1474.  
  1475. An advantage of putting all package files under /opt is that allows
  1476. that directory to be networked.
  1477.  
  1478. A very simple example - The mush Package
  1479. -----------------------------------------
  1480. To create an SVR4 package the following files should be created
  1481.  
  1482. copyright pkginfo prototype postinstall
  1483.  
  1484. copyright
  1485. ---------
  1486. This contains the copyright notice for the package. For example:
  1487.  
  1488.  
  1489. Mush is copyright (c) 1986, 1987, 1988, 1989, 1990, 1991 by Dan Heller.
  1490. All Rights Reserved.   This software is not in the public domain.
  1491.  
  1492. Redistribution of the unmodified source code is permitted as long as all
  1493. copyright notices remain intact and all other identifying notices remain
  1494. in the code and in the binary.  This includes message headers on outgoing
  1495. mail and the startup message.  Future releases may extract the release
  1496. version from the message headers of mush-originated messages to aid in
  1497. implementing features and providing backwards compatibility with previous
  1498. versions.  Modification of the source for personal use is permitted.
  1499. Modifications sent to the authors are humbly accepted and it is their
  1500. prerogative to make the mods official.  Only the "official" sources may be
  1501. redistributed and no sale of the code or any part thereof is permitted
  1502. without written consent from the authors.  Further, no part of the code
  1503. may be used in any other product, free or otherwise, without consent from
  1504. the authors.  Distribution of sources containing adaptations of the SunView
  1505. interface to XView or to any X11-based interface is expressly prohibited.
  1506.  
  1507. MUSH IS PROVIDED AS IS, WITHOUT WARRANTY.  AUTHORS HEREBY DISCLAIM
  1508. ALL WARRANTIES INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES
  1509. OF FITNESS FOR A PARTICULAR PURPOSE.
  1510.  
  1511. pkginfo
  1512. -------
  1513.  
  1514. pkginfo is an ASCII file that describes the characteristics
  1515. of the package along with information that helps control the
  1516. flow of installation.  It is created by the software package
  1517. developer.
  1518.  
  1519. Each entry in the pkginfo file is a line that establishes
  1520. the value of a parameter in the following form:
  1521.  
  1522. PARAM="value"
  1523.  
  1524. An example follows:
  1525.  
  1526. $ cat pkginfo
  1527. PKG="mush"
  1528. VERSION="7.2.5"
  1529. NAME="Mail Users Shell"
  1530. CATEGORY="application"
  1531. CLASSES="none"
  1532. PREDEPEND=mush
  1533. VENDOR="(c) 1989 Dan Heller"
  1534.  
  1535.  
  1536. For more information see pkginfo(4).
  1537.  
  1538. prototype - package information file
  1539. --------------------------------------
  1540.  
  1541. prototype is an ASCII file used to specify package
  1542. information.  Each entry in the file describes a single
  1543. deliverable object.  An object may be a data file,
  1544. directory, source file, executable object, etc.  This file
  1545. is generated by the package developer (most often using the
  1546. pkgproto command).
  1547.  
  1548. Entries in a prototype file consist of several fields of
  1549. information separated by white space.  Comment lines begin
  1550. with a ``#'' and are ignored.
  1551.  
  1552. An example follows:
  1553.  
  1554.  
  1555. $ cat prototype
  1556. i pkginfo
  1557. i copyright
  1558. i postinstall
  1559. d none /opt ? ? ?
  1560. d none /opt/bin ? ? ?
  1561. d none /etc ? ? ?
  1562. d none /etc/mail ? ? ?
  1563. f none /opt/bin/mush 0755 bin bin
  1564. d none /opt/lib/mush 0755 bin bin
  1565. d none /opt/man 0755 bin bin
  1566. d none /opt/man/man1 0755 bin bin
  1567. f none /opt/man/man1/mush.1 0644 bin bin
  1568. f none /opt/lib/mush/Mushrc 0644 bin bin
  1569. f none /opt/lib/mush/cmd_help 0644 bin bin
  1570. f none /opt/lib/mush/Mailrc 0644 bin bin
  1571. f none /opt/lib/mush/Gnurc 0644 bin bin
  1572. f none /opt/lib/mush/advanced.mushrc 0644 bin bin
  1573. f none /opt/lib/mush/sample.mushrc 0644 bin bin
  1574.  
  1575.  
  1576. For more information see prototype(4).
  1577.  
  1578. postinstall - postinstallation commands
  1579. -------------------------------------------
  1580.  
  1581. This script is run with root privilege after the installation (note
  1582. that a preinstall file can be created to run commands before the
  1583. installation). (Note that this script asks for input and 
  1584. strictly speaking that should be done thru a request script).
  1585.  
  1586. An example follows:
  1587.  
  1588. $ cat postinstall
  1589.  
  1590. echo "\n\t*** NOTE: To setup your From: address line edit /etc/mail/mush/Mushrc"
  1591. echo "\tAttempting to set this up. If not setup the From: line will default"
  1592. echo "\tto the system name. Its best to use a domain address i.e. site.domain"
  1593. echo "\talthough you must be registered."
  1594. echo "\tEnter your domain address --->\c"
  1595. read address
  1596. if [ "${address}" = "" ]
  1597. then
  1598.      echo "\tYou did not enter an address so /etc/mail/mush/Mushrc not setup."
  1599. else
  1600.         echo "\tYou entered \"$address\" as your domain name"
  1601.         echo "\tThis will now be entered in the /etc/mail/mush/Mushrc file."
  1602.         echo "\tIf you made a mistake edit the file by hand."
  1603. fi
  1604. sleep 2
  1605. echo "set hostname=\"$address\"" >>/etc/mail/mush/Mushrc
  1606.  
  1607.  
  1608. pkgmk - produce an installable package
  1609. ---------------------------------------
  1610.  
  1611. To build the package use pkgmk. 
  1612.  
  1613. NOTE: pkgmk requires root privilege.
  1614.  
  1615. For example to create the package in /var/spool/pkg.
  1616.  
  1617. Ensure you are the same directory as the packaging commands,
  1618. and that the target package files are installed  in the correct
  1619. locations (this simplifies things a lot).
  1620.  
  1621. # pkgmk -ai386 -r /
  1622.  
  1623. If you want to overwrite an existing package in the /var/spool/pkg
  1624. directory use the "-o" flag to pkgmk; pkgmk -ai386 -o -r /.
  1625.  
  1626. If you don't want to install the utility in its final 
  1627. destination prior to package creation, then a tree of files
  1628. can be created in a subdirectory call root, and the prototype
  1629. file edited as follows:
  1630.  
  1631. $ cat prototype
  1632. i pkginfo
  1633. i copyright
  1634. i postinstall
  1635. d none /opt ? ? ?
  1636. d none /opt/bin ? ? ?
  1637. d none /etc ? ? ?
  1638. d none /etc/mail ? ? ?
  1639. f none /opt/bin/mush=root/opt/bin 0755 bin bin
  1640. d none /opt/lib/mush=root/opt/lib 0755 bin bin
  1641. d none /opt/man=root/opt/man 0755 bin bin
  1642. d none /opt/man/man1=root/opt/man/man1 0755 bin bin
  1643. f none /opt/man/man1/mush.1=root/opt/man/man1/mush.1 0644 bin bin
  1644. f none /opt/lib/mush/Mushrc=root/opt/lib/mush/Mushrc 0644 bin bin
  1645. f none /opt/lib/mush/cmd_help=root/opt/lib/mush/cmd_help 0644 bin bin
  1646. f none /opt/lib/mush/Mailrc=root/opt/lib/mush/Mailrc 0644 bin bin
  1647. f none /opt/lib/mush/Gnurc=root/opt/lib/mush/Gnurc 0644 bin bin
  1648. f none /opt/lib/mush/advanced.mushrc=root/opt/lib/mush/advanced.mushrc 0644 bin bin
  1649. f none /opt/lib/mush/sample.mushrc=root/opt/lib/mush/sample.mushrc 0644 bin bin
  1650.  
  1651. Package creation is the simply:
  1652.  
  1653.         pkgmk -ai386 -o
  1654.  
  1655. (no -r / this time)
  1656.  
  1657. Creating a floppy copy
  1658. ----------------------
  1659.  
  1660. To create a floppy copy:
  1661.  
  1662. # pkgtrans spool diskette1 mush
  1663.  
  1664. Another Example - Sendmail 
  1665. ============================
  1666. This example uses the menu routines to generate a blue screen menu
  1667. upon installation.
  1668.  
  1669. The packaging tree is listed below:
  1670.  
  1671. $ find . -print
  1672. ..
  1673. ../install
  1674. ../install/copyright
  1675. ../install/i.save
  1676. ../install/menu.1
  1677. ../install/menu.err
  1678. ../install/menu.intro
  1679. ../install/postinstall
  1680. ../install/postremove
  1681. ../install/preinstall
  1682. ../install/r.save
  1683. ../install/request
  1684. ../pkginfo
  1685. ../prototype
  1686. ../root
  1687. ../root/etc
  1688. ../root/etc/mail
  1689. ../root/etc/mail/mailsurr
  1690. ../root/usr
  1691. ../root/usr/ucblib
  1692. ../root/usr/ucblib/sendmail
  1693. ../root/usr/ucblib/sendmail.cf
  1694. $                          
  1695.  
  1696. The contents of some of the key files above are listed below:
  1697.  
  1698. copyright
  1699. ---------
  1700.  
  1701. copyright - the copyright notice
  1702.  
  1703. i.save
  1704. ------
  1705.  
  1706. i.save - a script run by the system to backup files
  1707.  
  1708. #!/bin/sh
  1709. # i.save script
  1710. # script which backs up files
  1711. #
  1712. while read src dst ; do
  1713.  
  1714.         [ "$src" = /dev/null ] && continue
  1715.  
  1716.         if [ -f $dst ] ; then
  1717.                 echo $dst | cpio -pdmu $PKGSAV >/dev/null 2>&1
  1718.         fi
  1719.         cp $src $dst.tmp || exit 1
  1720.         mv $dst.tmp $dst || exit 1
  1721. done
  1722. exit 0    
  1723. # end of i.save script
  1724.  
  1725.  
  1726. menu.1
  1727. --------
  1728.  
  1729. menu.1 - part of the blue screen menu
  1730.  
  1731.  
  1732. ..pageno
  1733. Page %d of %d
  1734. ..ul
  1735. Sendmail Installation
  1736. ..helpbanner
  1737. Help on Sendmail Installation
  1738. ..hhelp_ban
  1739. Help on menus
  1740. ..ur
  1741. Introduction
  1742. ..ll
  1743. Please make a selection.
  1744. ..lr
  1745. Del=Cancel  F1=Help
  1746. ..top
  1747.  
  1748. This is a binary distribution of Sendmail 8.7.3 for UnixWare 2.x.
  1749. This package sets up your system to use Sendmail instead of the
  1750. default mailsurr based mailer.
  1751.  
  1752. AS SUCH, THIS IS AN UNSUPPORTED PACKAGE, TO BE USED AT YOUR OWN RISK.
  1753.            
  1754. This package saves all files it changes so they can be restored
  1755. on its removal.  You must restart TCP/IP after installing this package
  1756.  
  1757. sh /etc/inet/rc.restart
  1758.  
  1759. This port by :
  1760.  
  1761. Joe Doupnik, jrd@cc.usu.edu, Utah State University, 31 Dec 1995.
  1762.  
  1763. ..bottom
  1764. press 'ENTER' (or 'RETURN') to install.
  1765. ..help
  1766. The following assumptions are made about the installation:
  1767.  
  1768. o The directories used by this pacakage are
  1769.         /usr/ucblib             - for the mail executable
  1770.         /etc/mail               - for the mail configuration
  1771.  
  1772. ..helpinst
  1773. Esc=Quit Help  Del=Cancel  F1=Instructions
  1774. ..hhelpinst
  1775. Esc=Quit Instructions  Del=Cancel 
  1776.  
  1777.  
  1778. menu.err
  1779. ----------
  1780. menu.err - another part of the blue menu screens
  1781.  
  1782.  
  1783. ..pageno
  1784. Page %d of %d
  1785. ..ul
  1786. Sendmail Installation
  1787. ..helpbanner
  1788. Help on Sendmail Installation
  1789. ..hhelp_ban
  1790. Help on menus
  1791. ..ur
  1792. Error
  1793. ..ll
  1794. Press return when ready
  1795. ..lr
  1796. Del=Cancel  F1=Help
  1797. ..top
  1798.  
  1799.  
  1800.  
  1801.  
  1802.  
  1803.  
  1804.  
  1805.  
  1806. `echo $ERROR`
  1807. ..bottom
  1808. Press 'ENTER' (or 'RETURN') to continue.
  1809. ..help
  1810. ..helpinst
  1811. Esc=Quit Help  Del=Cancel  F1=Instructions
  1812. ..hhelpinst
  1813. Esc=Quit Instructions  Del=Cancel 
  1814.  
  1815.  
  1816. menu.intro
  1817. -----------
  1818. menu.intro - more of the blue menu
  1819.  
  1820.  
  1821. ..pageno
  1822. Page %d of %d
  1823. ..ul
  1824. Sendmail Installation
  1825. ..helpbanner
  1826. Sendmail Copyright Notice
  1827. ..hhelp_ban
  1828. Help on menus
  1829. ..ur
  1830. Introduction
  1831. ..lr
  1832. Del=Cancel  F1=View Copyright
  1833. ..ll
  1834. Press RETURN when ready
  1835. ..top
  1836. Welcome to the Sendmail installation.
  1837.  
  1838. This installs sendmail as the default mailer.
  1839. This package is copyrighted. To re-view the copyright notice press F1 or '?'.
  1840.  
  1841.  
  1842. ..bottom    
  1843. Press 'ENTER' (or 'RETURN') to continue.
  1844. ..help
  1845. The full notice may be found in /var/sadm/pkg/sendmail/install/copyright
  1846.  
  1847. Copyright (c) 1983, 1995 Eric P. Allman
  1848. Copyright (c) 1988, 1993
  1849.       The Regents of the University of California.  All rights reserved.
  1850.  
  1851.  
  1852. ..helpinst
  1853. Esc=Quit Copyright  Del=Cancel  F1=Instructions
  1854. ..hhelpinst
  1855. Esc=Quit Instructions  Del=Cancel
  1856.  
  1857.  
  1858. postinstall
  1859. -----------
  1860.  
  1861. postinstall - the script executed after the software is installed
  1862.  
  1863. #!/bin/sh
  1864. # postinstall script
  1865.  
  1866.  
  1867. if [ -f /etc/inet/config ] ; then
  1868.         if grep sendmail: /etc/inet/config >/dev/null ; then
  1869.                 :
  1870.         else
  1871.  
  1872.                 # Save old version with the packaging
  1873.                 echo /etc/inet/config | cpio -pdmu $PKGSAV 2>/dev/null
  1874.                 echo '8:/usr/ucblib/sendmail::y:/usr/ucblib/sendmail.cf:-bd -q2h :' >> /etc/inet/config
  1875.         fi
  1876. fi
  1877.  
  1878. echo /etc/init.d/smtpinit |cpio -pdmu $PKGSAV 2>/dev/null
  1879.  
  1880. TMP=/tmp/pkg$$
  1881. echo "#!/bin/sh \nexit 0" > $TMP
  1882. cat /etc/init.d/smtpinit  >>$TMP
  1883. cp $TMP /etc/init.d/smtpinit
  1884.                  
  1885. exit 0  
  1886. # end of postinstall script
  1887.  
  1888. postremove
  1889. -----------
  1890.  
  1891. postremove - script executed to removing the software
  1892.  
  1893. #!/bin/sh
  1894. # postremove used to restore original files
  1895.  
  1896. cd $PKGSAV
  1897. echo "Warning the following files have been restored, any changes"
  1898. echo "made to them since installing this package will be lost."
  1899. find . -type f -print|cpio -pdmuv /
  1900. exit 0 
  1901. # end of postremove
  1902.  
  1903.  
  1904. preinstall
  1905. ----------
  1906.  
  1907. preinstall - executed before installing files
  1908.  
  1909. #!/bin/sh
  1910. # preinstall - some dependency checks
  1911.  
  1912. rel=`uname -v |cut -f1 -d"."`
  1913. if [ "$rel" -ne "2" ]
  1914. then
  1915.         echo "This package requires UnixWare version 2.x to install."
  1916.         exit 1
  1917. fi
  1918. sh /etc/rc2.d/S81smtp stop
  1919.  
  1920. exit 0  
  1921. # end of preinstall
  1922.  
  1923. r.save
  1924. -------
  1925.  
  1926. r.save - class script to restore files
  1927.  
  1928.  
  1929. #!/bin/sh
  1930. #
  1931. # script which backs up files
  1932. #
  1933.  
  1934. cd $PKGSAV
  1935.  
  1936. while read file ; do
  1937.         if [ -f ./$file ]
  1938.         then
  1939.                 mv ./$file $file.tmp || continue
  1940.                 mv $file.tmp $file
  1941.         else
  1942.                 rm -f $file
  1943.         fi
  1944. done
  1945. exit 0   
  1946. # end of r.save script
  1947.  
  1948. request
  1949. -------
  1950.  
  1951. request - script to display the menus & handle the input
  1952.  
  1953. # geta question default
  1954. MENU=/usr/sbin/menu
  1955.  
  1956. cd $REQDIR || exit 1
  1957. rm -f /tmp/out.$$
  1958. $MENU -f menu.intro -o /tmp/out.$$
  1959. if [ ! -f /tmp/out.$$ ] ; then
  1960.          exit 1
  1961. else
  1962.         . /tmp/out.$$
  1963. fi
  1964.  
  1965. rm -f /tmp/out.$$
  1966. $MENU -f menu.1 -o /tmp/out.$$
  1967. if [ ! -f /tmp/out.$$ ] ; then
  1968.          exit 1
  1969. else
  1970.         . /tmp/out.$$
  1971. fi
  1972.  
  1973. echo "NPATH=$NPATH" >> $1  
  1974.  
  1975.  
  1976.  
  1977. pkginfo
  1978. -------
  1979. The pkginfo script has the save class defined so
  1980. that files can be backed up and restored using the 
  1981. i.save and r.save scripts
  1982.  
  1983. ARCH=i386
  1984. PKG=sendmail
  1985. VERSION=8.7.3
  1986. NAME=Sendmail Mailer
  1987. CATEGORY=system
  1988. DEPEND=sendmail
  1989. CLASSES=none save
  1990.  
  1991.  
  1992.  
  1993. prototype
  1994. --------
  1995. The prototype shows the save class being used for the
  1996. mailsurr, and old sendmail files.
  1997.  
  1998. i pkginfo
  1999. i preinstall=install/preinstall
  2000. i copyright=install/copyright
  2001. i menu.intro=install/menu.intro
  2002. i menu.1=install/menu.1
  2003. i menu.err=install/menu.err
  2004. i postinstall=install/postinstall
  2005. i postremove=install/postremove
  2006. i request=install/request
  2007. i i.save=install/i.save
  2008. i r.save=install/r.save
  2009. d none / ? ? ?
  2010. d none /usr ? ? ?
  2011. d none /etc ? ? ?
  2012. d none /etc/mail ? ? ?
  2013. d none /etc/ucbmail ? ? ?
  2014. d none /usr/ucblib ? ? ?
  2015. f save /etc/mail/mailsurr=root/etc/mail/mailsurr 444 root mail
  2016. f save /usr/ucblib/sendmail=root/usr/ucblib/sendmail 04111 root mail
  2017. f save /etc/ucbmail/sendmail.cf=root/usr/ucblib/sendmail.cf 444 bin bin
  2018.  
  2019.  
  2020. Creating the package
  2021. --------------------
  2022. In this case
  2023.         pkgmk -ai386 -o 
  2024.  
  2025. Subject: D42) How to build binaries on UnixWare to run on other SVR4 systems 
  2026.    such as Solaris x86?
  2027.  
  2028. Scott Raney <raney@metacard.com> writes:
  2029.  
  2030. 1) Always link libraries dynamically. 
  2031.  
  2032. 2) We had to put the following hack in to make UnixWare 2.0 binaries
  2033. run on Solaris 2.4:
  2034. #ifdef UNIXWARE
  2035. extern "C" {
  2036. int sys_nerr;
  2037. int     *__thr_errno()
  2038. {
  2039.   return &errno;
  2040. }
  2041. }
  2042. #endif
  2043.  
  2044. 3) Be sure to thoroughly test all code that runs subrocesses,
  2045. especially code that reads and writes to pipes to the child processes.
  2046. The gotchas here are too obscure to detail here, but they'll get you
  2047. if you don't hunt them down.      
  2048.  
  2049.  
  2050. John Moyer (jrm@questconsult.com) writes :
  2051.  
  2052. To build binaries that run under Dell Unix from Unixware 2.0x, static
  2053. linking is best. Static linking is not possible with Athena Widgets or
  2054. wide character support or anything else that requires -lnsl.
  2055.  
  2056. To build X11R6 binaries from UnixWare 2.0x to run under Unixware 1.1.4
  2057. I found it necessary to link with libc.so and libnsl.so from unixware
  2058. 1.1.4. This is not necessary if libXaw.so is built with the x.org 
  2059. wide character support instead of using -lw.
  2060.  
  2061. Binaries with "long double" variables do not seem to run under the
  2062. Linux iBCS emulation. Static linking seems to me to be best for Linux
  2063. iBCS.
  2064.  
  2065.  
  2066. Acknowledgements   
  2067. ---------------
  2068.  
  2069. Special thanks to Darren R. Davis and the Novell UnixWare
  2070. Developer Support team for getting this FAQ going and to
  2071. those folks who've made suggestions and contributions either
  2072. directly or via the netnews.
  2073.  
  2074.  
  2075. --
  2076. Andrew Josey,  Disclaimer: Any views expressed are not those of
  2077. my employer, either past, present or future.
  2078.  
  2079.