
           Linux Gazette... making Linux just a little more fun!
                                      
         Copyright  1996-98 Specialized Systems Consultants, Inc.
     _________________________________________________________________
   
                       Welcome to Linux Gazette! (tm)
     _________________________________________________________________
   
                                 Published by:
                                       
                               Linux Journal
     _________________________________________________________________
   
                                 Sponsored by:
                                       
                                   InfoMagic
                                       
                                   S.u.S.E.
                                       
                                    Red Hat
                                       
                                   LinuxMall
                                       
                                Linux Resources
                                       
                                    Mozilla
                                       
   Our sponsors make financial contributions toward the costs of
   publishing Linux Gazette. If you would like to become a sponsor of LG,
   e-mail us at sponsor@ssc.com.
   
   Linux Gazette is a non-commercial, freely available publication and
   will remain that way. Show your support by using the products of our
   sponsors and publisher.
     _________________________________________________________________
     _________________________________________________________________
   
                             Table of Contents
                            June 1998 Issue #29
     _________________________________________________________________
   
     * The Front Page
     * The MailBag
          + Help Wanted
          + General Mail
     * More 2 Cent Tips
          + Linux Kernel 2.1.102 Error Patch
          + Tip for using Windows 95 Button in X
          + Re: Usershell on Console
          + IBM LAN Adaper for Ethernet
          + Easy Access to Removable Media
          + Re: bpp 16 question
          + Re: Finite Elements Programs
          + Re: How to Enable Swapping
          + Re: Slackware
          + Re: about::mozilla
          + Tips Contents for More Tips!
     * News Bytes
          + News in General
          + Software Announcements
     * The Answer Guy, by James T. Dennis
     * Building an Audio CD Player, Part 2, by Michel Hamilton
     * EMACSulation, by Eric Marsden
     * The Importance of Adopting an In-House Linux Expert, by Carlo
       Prelz
     * Mastering Kernel Modules with Caldera, by David Nelson
     * Replacing Windows NT Server with Linux, by Quinn P. Coldiron
     * Revisiting VIM, by Andy Kahn
     * Sun Joins Linux International, by Marjorie Richardson
     * Tom's 2 Cent Tips, by Tom Bryant
     * UniForum 1998, by Phil Hughes
     * Using rdist for Backups, by John Pate
     * The Back Page
          + About This Month's Authors
          + Not Linux
       
   The Answer Guy
   
   The Graphics Muse Will Return
     _________________________________________________________________
   
   The Whole Damn Thing 1 (text)
   The Whole Damn Thing 2 (HTML)
   are files containing the entire issue: one in text format, one in
   HTML. They are provided strictly as a way to save the contents as one
   file for later printing in the format of your choice; there is no
   guarantee of working links in the HTML version.
     _________________________________________________________________
   
   Got any great ideas for improvements? Send your comments, criticisms,
   suggestions and ideas.
     _________________________________________________________________
   
   This page written and maintained by the Editor of Linux Gazette,
   gazette@ssc.com
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                                The Mailbag!
                                      
                    Write the Gazette at gazette@ssc.com
                                      
                                 Contents:
                                      
     * Help Wanted -- Article Ideas
     * General Mail
     _________________________________________________________________
   
                        Help Wanted -- Article Ideas
     _________________________________________________________________
   
   Date: Wed, 13 May 1998 13:39:17 -0700
   From: Michael Vanecek, webmaster@mjv.com
   Subject: Blender
   
   I'd be tickled pink if one of your writers/Linux gurus would take a
   peek at the new 3D development package called Blender and write about
   it. Info can be found at:
   
   http://www.neogeo.nl/blender.html
   
   It's still in beta, but appears to be a sharp product and will appeal
   to us graphic artists looking for new tools for Linux.
   
   Thanks, Mike
     _________________________________________________________________
   
   Date: Sun, 24 May 1998 16:35:41 -0600
   From: Phil Reardon, pcr@pcrt.com
   Subject: Article Ideas
   
   I think a lot of people would be interested in an article on Linux
   related posters, which would have good eye appeal and provide a
   resource to the community for ordering these collectibles. Someone
   would have to locate all of them first, however.
     _________________________________________________________________
   
   Date: Sat, 02 May 1998 15:48:04 -0700
   From: "Joseph Mugerwa", joe.jtm@mailcity.com
   Subject: Sound card with radio on it
   
   I am intending to install Red Hat 5.0 to my 486: PC and my question is
   that I have a ISA sound card (SF16-FMI) with radio on it, it's 100% SB
   compatible,and has a IDE connection on it and it's not PnP will it be
   able to work and in particular the radio please help I enjoy listening
   to radio
   
   Joseph
     _________________________________________________________________
   
   Date: Mon, 04 May 1998 21:08:35 -0700
   From: slappy, slappy@pcisys.ne
   Subject: Best Linux Motherboard
   
   Hi. I recently bought a Tyan Turbo AT S1571 motherboard to run my Red
   Hat Linux www server on. The keyboard freaks out when I attempt to
   install Linux. No BIOS update is available. Do you have any
   suggestions as to what motherboard/chip set combinations work well
   with Linux? I have searched and found only generic information, I'm
   looking for something a bit more specific. Intel, ABit, Asus, DFI,
   SuperMicro??? I'm planning on using a 233MHz MMX Pentium.
   
   Slappy (slappy@pcisys.net)
     _________________________________________________________________
   
   Date: Wed, 06 May 1998 12:49:23 +0800
   From: Guan Yang, guan@wk.dk
   Subject: Permissions problem
   
   After I have tried the 'su' command, all permissions for user accounts
   seem to be gone (Slackware 3.4). When it try to login with a normal
   user account, if says that I don't have permission to execute
   /bin/bash. I have checked, and bash is world readable and world
   executable.
     _________________________________________________________________
   
   Date: Wed, 13 May 1998 12:46:47 +0200 (MEST)
   From: Thomas Hotz, bombur@uni-koblenz.de
   Subject: Help wanted! - PS/2-Intellimouse
   
   I have just bought a Microsoft Intellimouse, because I thought it was
   a good choice if you must use Windows and can use Linux. The Mouse is
   connected to the PS/2-Mouseport. Here is my problem: I want to use the
   wheel-button as the middle button in X, but in xf86config I only have
   the choice between IntelliMouse or PS/2Mouse, there is no combination
   of both. PS/2Mouse will enable the mouse, but the wheelbutton is not
   recognized, the other way the movements of the mouse are not correctly
   recognized, e.g. I cant move the pointer through the middle of the
   screen. Anybody got a solution for this?
   
   Thomas Hotz
     _________________________________________________________________
   
   Date: Mon, 11 May 1998 18:32:20 +0000 (UTC)
   From: Christopher Butler, chrisb@sandy.force9.co.uk
   Subject: Printer
   
   I have here an Epson Stylus COLOR 400 printer, and I was wondering if
   I can get one of these beasts to print graphics in Linux (it only does
   text atm).
   
   I've got Aladdin Ghostscript 3.33 (4/10/1995) currently installed, but
   setting that up was a mystery to me.
   
   Pointers to HOWTOs would also be welcomed :-)
   
   Chris Butler
     _________________________________________________________________
   
   Date: Mon, 18 May 1998 12:12:16 -0400 (EDT) From: Randy Shaver,
   randy@gconn.net
   Subject: BJ-200e
   
   I am having a very difficult time setting up my Cannon BJ-200e, has
   anyone been able to configure Linux correctly to print from this?
   
   Randy Shaver
     _________________________________________________________________
   
   Date: Fri, 15 May 1998 17:42:00 +0000
   From: Patrick Leung, wt.leung@student.unsw.edu.au
   Subject: Compilation Error with Red Hat 5.0 on Cyrix CPU
   
   I'm using a Cyrix 6x86 P150+ Machine with 80MB RAM. Everything when I
   compile stuff with the gcc compiler (2.7.2.3) that come with RH5.0, I
   get the error message like "cc1 internal error,signal 11". I know this
   is a bug with Cyrix CPU but does anyone know how to fix it? Please
   tell me.
     _________________________________________________________________
   
   Date: Thu, 21 May 1998 19:06:55 +0100
   From: Andrew Crook, Andrew@andycrook.demon.co.uk
   Subject: X and list probs
   
   I have noticed a real problem with X eg that the fonts listing in
   Netscape and MANY APPS the list goes off the screen and many can not
   be seen how can i stop this problem?
     _________________________________________________________________
   
   Date: Wed, 27 May 1998 11:20:26 +0800
   From: "Felix", felix@omen.com.au
   Subject: definitions
   
   Let me introduce myself, I am Felix. I am _totally_ new to not just
   Linux but computers in general. I have had a computer for the last
   ....two years, and in all that time was restricted to the limitations
   Windows puts on me. This is because , like many users, I started with
   the program that came with my setup. Windows is _great_ for someone
   who knows _nothing_ of computers. It is all point and click
   accessible. But like anyone who uses a computer for a while, I have
   come to realize that Windows is not the be all and end all of my
   possibilities. Now I want more. Since I got on the Net, I have
   realized this and found Linux. I am in the process of browsing Linux
   for a grounding in the unfamiliar world of Linux. It is
   ................most enlightening.
   
   One 'problem' I have encountered is strong, complete definitions of
   terms. If I post a list of terms I have heard in the new groups and
   ask for explanations, I get many replies { the Linux community is
   amazingly tolerant of newbies, and help most unselfishly!} but the
   common thread running through them is that each explanation is
   slightly different to the next. While I realize that some of the
   answers I get are subject specific, some definitions seem to vary from
   application to application, even from distribution to distribution.
   Again, I realize that each distribution may focus on different
   capabilities of applications.
   
   What I want to know is this: Is there a book, magazine, net site or
   whatever that lists in dictionary form properties and definitions of
   Linux?
   
   Thank you, Felix
   
     (Good books include Linux in a Nutshell from O'Reilly and Linux for
     Dummies Quick Reference from IDG. While it is not specifically for
     Linux, I find UNIX: The Open System's Dictionary from Resolution
     Business press quite useful. --Editor) 
     _________________________________________________________________
   
   Date: Wed, 27 May 1998 01:42:02 +0900
   From: Maximo Ramos, ramos@nuri.net
   Subject: Deception about Linux
   
   I wonder why I find so often in many home pages about Linux that it
   will run fine in a 386 with 8 MB RAM, JA! Keep in mind that novice end
   users (like me) who are trying to escape from Windows 95 by trying
   something else, confuse Linux with the X Window System. Did you try to
   run Linux and XFree86 in such a machine? Tell people the truth! Is
   anyone using X Windows in a 14 inch monitor? It's ugly! Today I paid
   the bill to buy a 17 inch monitor, ouch!!!! Again, tell people the
   truth when you talk about hardware requirements to run Linux and X.
   
   Of course, in some home pages they say that if you want to run the X
   Window System you need a "little bit" more hardware, but what is
   exactly "a little bit"? Come on!
   
   Why am I writing this? Because I own a 486DX2 with 32MB of RAM, and I
   said myself : Hey, if Linux runs fine in a 386 with 8 MB of RAM,
   running Linux in my computer will feel like having a Pentium! But that
   is not the true. X works good but more slowly than Windows 95, even
   the Internet is slower, incredible!
   
   So, I request one thing, tell the people (end users) on which hardware
   Linux will run fast (with X Windows included); in my case, I have to
   buy a new computer, at least a Pentium II 233 MHz. I thought MS
   Windows was the only OS hungry resource.
   
   Well, one more thing, any tips to improve the speed of my Internet
   Connection?
   
   What is the difference between having the PPP support as a module or
   included in the kernel? Which is more recommendable?
   
   Anyone has successful installed ICQ for JAVA? When I download some
   libraries, which one should I choose? static or dynamic? How do I know
   what is the correspondent to my system? By the way, It is Red Hat
   Linux 5.0. My video card is Cirrus Logic clgd5426 with 1 MB.
   
   Talking about e-mails, I heard about sendmail and so on, but I use
   Netscape for Linux to send and receive e-mails, Which one is better?
   Is sendmail only for servers?
   
   Please, do I have to buy a new computer anyway?
   
   cheers, Desperado
     _________________________________________________________________
   
   Date: Thu, 14 May 1998 04:04:14 -0400 (EDT)
   From: arunk@m-net.arbornet.org
   Subject: Serial line overrun
   
   When I'm downloading on one virtual console and doing something else
   on another (especially accessing the hard disk) I get the message
   'cua1 1 input overrub(s). Why does this happen? What should I do to
   stop this? Please help me. Thanks.
     _________________________________________________________________
   
   Date: Sun, 31 May 1998 21:28:53 +0100
   From: Martin Cannell martin@cannell.prestel.co.uk
   Subject: Linux
   
   Hi, a great magazine.
   
   A bit advanced for me though. Do you know where to get an idea about
   how to install Linux?
   
     (Try the Linux Installation HOWTO by Eric Raymond:
     http://www.ssc.com/linux/LDP/HOWTO/Installation-HOWTO.html. In fact
     you might want to search around the LDP (Linux Documentation
     Project) for other things of interest to newbies. You might also
     want to check out some of the earlier issues of Linux Gazette and
     our semi-regular column "Clueless at the Prompt" by Mike List.
     --Editor) 
     _________________________________________________________________
   
                                General Mail
     _________________________________________________________________
   
   Date: Thu, 30 Apr 1998 08:03:52 +0000
   From: Chris Fischer, protek@brigadoon.com
   Subject: BusLogic Support for Linux
   
   This is just a little FYI for anyone interested in the web page for
   Linux BusLogic support.
   
   http://www.dandelion.com/Linux/BusLogic.html
   
   Chris
     _________________________________________________________________
   
   Date: Fri, 01 May 1998 09:14:06 +0000
   From: Lars Hamren, hamren@sdu.se
   Subject: Web Speed
   
   Your home page just took me 45 seconds to load, mainly due to the nice
   but far too large gifs. I think that the following holds:
     * A lot of Linux users are accessing the gazette via modem.
     * The typical Linux user is not impressed by a fancy surface, but
       would rather have fast loading pages.
       
   Lars
     _________________________________________________________________
   
   Date: Sun, 3 May 1998 12:02:54 -0400
   From: "Tim Gray", timgray@lambdanet.com
   Subject: Article on home networking.
   
   There is one part of the home networking article I strongly disagree
   with.
   
   "The software and hardware for networking can be expensive."
   
   10baseT network cards sell for about $14.00USD that work well with
   Linux.. even less if you want the holy grail of a card with actual
   jumpers on it! A hub - 8 port will cost you a whole $60.00USD Buy the
   cheapest you can get your hands on... this will be plenty for a home
   network.
   
   Now the software...... it comes with your Linux distribution, and
   win95 has it built in.... So my network at home...
   
   4 PC's Win95, 2 servers, 1 router, Full-time Internet connection......
   Less than $300.00 total to network it, including a 1000' spool of
   category 5 cable and a huge bag of connectors. and the wall plates
   were 1.95 each (Cat 3 I don't need 100baseT capability) Oh yes, one
   expensive part.. the connector crimper.... it cost 29.95USD one
   weekend of running wire and a week of fighting with windows and VOILA!
   home network!
   
   Yes you can get more expensive stuff..... You can spend thousands on a
   hub.. or even more on a switch (A glorified hub) especially if you
   want that gleaming white box that says Cisco networking on it... but
   it wont work any better than the 60 dollar blue thing that has Chinese
   writing on it, not in a home environment. No networking your house is
   not expensive, it's dirt cheap!
   
   BTW, my servers and router are all Linux machines that were built from
   "junk" computers that were given to me or found in a corporate garbage
   dumpster!
     _________________________________________________________________
   
   Date: Wed, 13 May 1998 17:43:04 +0200 (CEST)
   From: Rob van der Putten, rob@sput.sput.dsl.nl
   Subject: Modeline for TV
   
   Though I have been using Linux for since 1.2.8, I still discover
   something new every week or so. Yesterday I discovered the online
   version of the Linux Gazette and was pleasantly surprised to read the
   following:
   
     I have shamelessly stolen this from USENET, because I feel this
     excellent information should appear within the Linux Gazette. I
     hope the original author don't mind. :-) From: Rob van der Putten
     
   I don't mind at all. I just wanted to say that I wrote a html page
   about it: http://www.sput.dsl.nl/~rob/tv-x.html
   
   Regards, Rob
     _________________________________________________________________
   
   Date: Wed, 13 May 1998 02:05:22 +0800
   From: "Kevin Ng", kng@HK.Super.NET
   Subject: Swap problem solved! Thanks...
   
   Dear Linux fans,
   I'd like to say thanks to all who have responded and offered help to
   the swap problem. A number of you reminded me that I had to do a
   mkswap before I can enable the swap space with swapon.And now my
   system is running smoothly, with occasional swap. Once again thanks to
   you all. Linux peer support is excellent.
   
   Kevin
     _________________________________________________________________
   
   Date: Tue, 12 May 1998 00:37:34 -0500
   From: Todd Myers, tmyers@autobahn.mb.ca
   Subject: good article
   
   I just read the article "Marketing Linux" by Jim Schweizer and agree
   with his points on this subject. Being involved with microcomputers
   for the last 12-14 years I've noticed that each successful platform
   has at least one 'killer app' that launched it onto people's
   desktops...VisiCalc -> AppleII, DTP -> Mac, Office Suites -> Windows.
   
   It appears that Linux has ,at present, 2 killer apps to use for it's
   launch point...Apache and Samba. Since Linux is, at present, better
   poised in a server role, these 2 apps are beginning to gain Linux it's
   recognition. The only thing that will keep Linux off the desktop is
   the lack of a standard GUI. Though this will change as this is
   dissected and dealt with with the amazing collaboration efforts that I
   have witnessed with other Linux-related issues in the past 12 months.
   
   Later, Todd
     _________________________________________________________________
   
   Date: Thu, 28 May 1998 18:40:48 +0100 (WET DST)
   From: 40334022 Dani Pardo Portas, dp4022@speedy.udg.es
   Subject: Proprietary formats
   
   I just can't stop being fascinated with Issue 18, The Answer Guy where
   the editor talks about proprietary formats. Even now, I often think
   about the issue of word processors and proprietary formats (BTW, I've
   started learning lout :).
   
   And now that there is so much interesting talk about philosophy of
   computers and programming, I'd just like to point everyone interested
   to LG-issue 18:
   
   http://www.linuxgazette.com/issue18/lg_answer18.html (users and
   mounted disks)
     _________________________________________________________________
   
   Date: Mon, 04 May 1998 14:44:50 -0500
   From: Clive Bittlestone, clyvb@asic.sc.ti.com
   Subject: Linux in EDA - hot news topic
   
   Just in case you had not already heard, Linux vs NT is a hot item in
   my area of the CAE/CAD industry. Integrated System Design magazine had
   a strawman poll last month, and based on the overwhelming response,is
   organizing a public forum during DAC-week [a big industry conference].
   
   http://www.isdmag.com/linuxvsnt.html
   
   From what I can tell, NT is being touted as the next OS on PC's [vs
   solaris/Ultrix/hp-os etc] Some engineers don't like that and there is
   some form of pushback.
   
   There is quite a buzz amongst the Linux users I work with. We hope
   this will encourage CAD-Vendors to support Linux !!
   
   These are my own opinions, and not those of Texas Instruments.
   
   Regards, Clive Bittlestone
     _________________________________________________________________
   
   Date: Sat, 09 May 1998 03:38:17 -0700
   From: Jim Dennis, jimd@starshine.org
   Subject: Open Letter Re: Linux on Dell Hardware
   
   To: Mr. Michael Dell, CEO, Dell Computers cc: T.R. Reid Re: Linux on
   Dell Hardware
   
   Dear Mr. Dell,
   
   Please forward this to members of your marketing staff.
   
   It is with great disappointment that I read comments by one of your
   representatives, a Mr. T. R. Reid to the effect that "none of Dell's
   customers" use Linux (*).
   
   This is patently untrue. I have personally administered a number of
   Linux servers that were running on Dell Dimension desktops. I have
   also often recommended them to my clients, despite the fact that your
   company offers no option to unbundle software from the system
   (software which is utterly useless for my applications).
   
   Obviously my advice was misguided. I clearly have failed in my duty,
   as a consumer, to provide you with proper feedback --- and this as
   resulted in a gross display of ignorance regarding the needs and
   preferences of your customers (at least the ones I represent).
   
   Forthwith I'm retracting all recommendation of your products from all
   Starshine's customers where the intent is to use the system under
   Linux. I maintain a list of smaller hardware companies which do
   provide Linux, FreeBSD, and other alternatives to meet the needs of
   their customers.
   
   I'll be recommending VAResearch, PromoX, Telenet, SWT, Apache Systems,
   Microway, and many others until you offer your customers a choice in
   the software that's bundled with your systems. I personally consider
   it a pity since your hardware has never required any special tweaks or
   considerations to run with any distribution of Linux or FreeBSD that
   I've ever installed on it.
   
   This will be posted to a few Linux and FreeBSD venues as an open
   letter so that you can be provided with *honest* feedback from real
   customers. Hopefully with the co-operation from other interested
   parties we can overcome this regrettable failure in communication.
   You're comments have underscored the need for consumers every where to
   make their requirements and preferences known --- and we must no
   longer simply accept the "extra" and unwanted components that our
   vendors foist on us.
   
   It is time to just say "No!" to software that we'll simply be
   replacing.
   
   Thank you for your attention to this matter. My apologies for not
   providing this feedback sooner.
   
   (*) The precise quote was:
   
   "I haven't been able to find any examples of customers requesting
   Linux"
   
   ... and it can be read at:
   
   http://www.zdnet.com/zdnn/content/inwo/0427/310649.html
   
   --
   Jim Dennis, consulting@starshine.org
   Proprietor, Starshine Technical Services: http://www.starshine.org/
     _________________________________________________________________
   
               Published in Linux Gazette Issue 29, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Next 
   
      This page written and maintained by the Editor of Linux Gazette,
      gazette@ssc.com
      Copyright  1998 Specialized Systems Consultants, Inc.
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                               More 2 Tips!
                                      
               Send Linux Tips and Tricks to gazette@ssc.com 
     _________________________________________________________________
   
  Contents:
  
     * Linux Kernel 2.1.102 Error Patch
     * Tip for using Windows 95 Button in X
     * Re: Usershell on Console
     * IBM LAN Adaper for Ethernet
     * Easy Access to Removable Media
     * Re: bpp 16 question
     * Re: Finite Elements Programs
     * Re: How to Enable Swapping
     * Re: Slackware
     * Re: about::mozilla
     * Re: Rebooting without logging in as Root
     * Re: Running an ATAPI ZIP Drive
     * Re: Enabling Swap Space
     * Re: Problems using Menus in X
     * Music Typesetters
     * BASH hostname Completion
     * Re: xdm and depth
     * Re: Shutdown and root
     * Printing with Linux
     * Re: Finite Elements Programs
     * Re: Hot to Enable Swapping
     * Cuckoo Clock
     _________________________________________________________________
   
  Linux kernel 2.1.102(3) error - patch!
  
   Date: Sat, 23 May 1998 16:20:07 +0000
   From: Yaroslav Rosomakho, alons55@dialup.ptt.ru
   
   Hello. I have found that make menuconfig and lowlevel sound drivers
   won't work in 2.1.102 & 2.1.103 (latest kernels). I have written a
   patch:
   http://yaroslav.hypermart.net/linux
   
   tell people about it!
   
   Yaroslav Rosomakho.
     _________________________________________________________________
   
  Tip for using Windows 95 buttons in X
  
   Date: Wed, 29 Apr 1998 20:18:00 +0200 (MET DST)
   From: Andreas Ehliar, tamyrlin@futurniture.se
   
   I am sure that I am not the only one using a keyboard with Windows 95
   buttons. Most people I know tend to ignore them, since they are not
   very useful in Windows 95, and even less so in Linux. But they are
   supported in the Linux kernel. That is, they do generate key codes
   which applications could use, if they only know what to look for.
   
   So, how do I get X to use the offending buttons? In the following
   example, I will show how I configured X and fvwm2 to allow me to move
   a window by pressing the left Windows 95 button, and the left mouse
   button anywhere in the window. I can also resize the window by
   pressing the left Windows 95 button and the right mousebutton anywhere
   in the window. This greatly simplifies things for me, since I don't
   have to locate the titlebar, or a border of the window to move it. So,
   how did I accomplish this? First, I created a file named .Xmodmap in
   my home directory with the following two lines:

keycode 115 = Hyper_L
add mod4 = Hyper_L

   This will map the left Windows 95 button to Hyper_L, and map Hyper_L
   to mod4.
   
   I added the following line to .xsession to actually load the modified
   keymap:

xmodmap $HOME/.Xmodmap

   Note that .xsession is usually executed if you use xdm to log on. If
   this is not the case, you need to find the relevant file on your
   computer system. Some likely candidates are .xinitrc, or .Xclients,
   however, YMMV.
   
   To actually use mod4 I modified my .fvwm2rc by adding the following
   lines:

# I have bound my left win95 button to mod4, and by holding down it
# I can move and resize my window without bothering to find a border or
# titlebar
Mouse 1 W       4       Move
Mouse 3 W       4       Resize

   What these lines does is to specify that if you press the left mouse
   button (1) in a window (W) while pressing mod4 (4) you will move the
   window. (Move) If you want to know more about these lines, you should
   study the fvwm2 man page.
   
   So, read in your .Xmodmap, restart fvwm2, and enjoy the added
   functionality. Now all that is left is to replace that Windows logo
   with a penguin :)
   
   Final notes:
   
   * This is only an example, you will probably need to modify some paths
   to suit your system.
   
   * It is also possible that you already have a button bound to mod4. In
   that case, you should probably think twice before binding another
   button to it.
   
   * If you don't use fvwm2 as your window manager,you should read the
   documentation that comes with your window manager to figure out how to
   do the above mentioned configuration.
   
   * If you want to bind the other two window 95 buttons, the scan codes
   for them are 116 respectively 117. This sort of information is by the
   way available using the xev program.
   
   Andreas Ehliar
     _________________________________________________________________
   
  Re: Help Wanted (usershell on console without logging in)
  
   Date: Thu, 30 Apr 1998 09:38:03 -0700
   From: Rick Bronson, rick@efn.org
   
   I've read, with interest, the good ideas people have submitted about
   setting up Linux to be more stand alone. I've worked on this issue on
   and off for some time now and would like to share my ideas.
   
   I've often thought that there needs to be a Linux distribution that
   has an automatic startup as the default. One of the reasons that MSDOS
   (as bad as it was) was popular was because it wasn't burdened with
   "security" items like logging in. Most of us that use Linux at home
   don't need to waist time logging in every day. If we had a
   distribution of Linux that booted up into X we would have a lot more
   users.
   
   My goals are as follows (all done automatically from power up):
   
   1. From power up, automatically login.
   
   2. Bring up X Windows.
   
   3. If I haven't been connected to my ISP (via PPP) in the last 4 hours
   then connect.
   
   3.1 Start up Netscape, get mail from my ISP (via cron), and check it
   every minute.
   
   3.2 If I haven't read USENET news today then fire up newsreader and
   automatically to thru and apply kill files to all articles and leave
   newsreader just showing what's left.
   
   3.3 (I admit, this one is weird) Telnet into my local library and
   check to see if I have overdue books.
   
   For the purposes of this 2 cent tip, I'm going to cover #1 & #2.
   (NOTE: replace every occurrence of "username" with your real login
   name).
   
   1. Add this to the bottom of your /etc/inittab (for Debian), unless
   you have an rc.local file

rc:12345:wait:/etc/init.d/rc.local

   1a (if you don't have an rc.local file) Make an /etc/init.d/rc.local
   file with this in it:

#!/bin/bash
echo "Auto login of user username"
cd /home/username
su - username

   Set permissions of rc.local to:

  -rwxr-xr-x   1 root     root           96 Jun 29  1997 rc.local

   By doing:

chmod 755 rc.local

   1b (if you have an rc.local file) Add this to the bottom of your
   rc.local

echo "Auto login of user username"
cd /home/username
su - username

   2. Add the following to the bottom of your ~/.bash_profile:

if [ "`tty`" = "/dev/console"  -o "`tty`" = "/dev/tty0" ]
then
  startx
fi

   That's it! This has been tested under Slackware (a long time ago) and
   under Debian, recently. Please give me any feedback.
   
   Thanks, Rick Bronson
     _________________________________________________________________
   
  IBM Lan Adapter for Ethernet
  
   Date: Fri, 01 May 1998 00:23:21 +0000
   From: Brian Hall, brihall@pcisys.net
   
   I believe this is the same card I have. I have two on my home LAN, one
   in my Linux box and the other in a Win95 box. In Linux, use the ne2000
   compatible network driver, found under "Other ISA" network cards in
   the kernel configuration. To configure the card itself, you will need
   to run a DOS program. The setup program is contained in an archive
   called "ETILAN.EXE".
     _________________________________________________________________
   
  Easy Access to Removable Media
  
   Date: Fri, 1 May 1998 10:30:52 +0100 (BST)
   From: Karsten Ballueder, karsten@phy.hw.ac.uk
   
   Here's a little tip that makes life much easier. I always found it
   annoying to manually mount and unmount floppies, CD-ROMs or my ZIP
   drive, so eventually I decided to use the amd automounter for that.
   
   The configuration is somehow tricky, but once it's set up, it works
   like a charm.
   
   For amd to work, you need to create a mountmap /etc/amd.direct= . Mine
   looks like this:

zip type:=3Dprogram;fs:=3D"/.amd/myhost/zip";mount:=3D"/bin/mount mount=
-tvfat -o user,rw,conv=3Dbinary,nosuid,uid=3D502,gid=3D100,umask=3D0000=
,quiet
/dev/sda4 ${fs} ";unmount:=3D"/bin/umount umount ${fs}"

cdrom type:=3Dprogram;fs:=3D"/.amd/myhost/cdrom";mount:=3D"/bin/mount m=
ount
-tiso9660 -o user,ro,conv=3Dbinary,nosuid,uid=3D502,gid=3D100,umask=3D0=
000
/dev/cdrom ${fs} ";unmount:=3D"/bin/umount umount ${fs}"

A type:=3Dprogram;fs:=3D"/.amd/myhost/A";mount:=3D"/bin/mount mount -tv=
fat -o user,rw,conv=3Dbinary,nosuid,uid=3D502,gid=3D100,umask=3D0000,qu=
iet /dev/fd0 ${fs} ";unmount:=3D"/bin/umount umount ${fs}"

   Where you will need to replace "myhost" with your machine's hostname.
   Like this it will automount the ZIPdrive, a CD-ROM and the first
   floppy in a set of directories created under /.amd .
   
   To start amd, you will usually use something like a script
   /sbin/init.d/amd, which should contain a line like:
   /usr/sbin/amd -l syslog -c 30 -w 30 -x all -a /.amd -- /tmpmnt
   /etc/amd= .direct &=20
   
   This will start amd and give it a 30 second timeout for unmounting
   directories. You also need to create a directory called /tmpmnt where
   you can access the devices. For easy access, I have create symbolic
   links /zip, /A and /cdrom pointing to /tmpmnt/zip, /tmpmnt/A and
   /tmpmnt/cdrom.
   
   Now, when you try to access any of these directories, amd will
   automatically mount the device with the options specified in
   /etc/amd.direct. Once you no longer access it, it will get unmounted
   after 30 seconds.
   
   Oh, if it doesn't unmount your device, you can use thefuser /dir
   command to check which of your processes uses it.
   
   Karsten Ballueder
     _________________________________________________________________
   
  Re: bpp 16 Question
  
   Date: Sun, 3 May 1998 14:07:55 +0200 (MET DST)
   From: Roland Smith, rsmit06@ibm.net
   
   To: Denny@ele.kth.se
   You asked in the Linux Gazette #28:
   
     Hi, I'm tired of starting my X-session with 'startx -- -bpp 16' to
     get 16 biplanes instead of the default 8. How do I get xdm to run
     with 16 bpp? If I use it now, it starts X with 8bpp on my Red Hat 5
     installation.
     
   Assuming you're using the XFree86 server:
   
   Edit your XF86Config file.
     * Look for the "Screen" section, then the subsections marked
       "Display" (you can have more then one).
     * Make sure the display subsection which has a depth of 16 is listed
       first.
       
   Hope this helps.
   
   Roland
     _________________________________________________________________
   
  Re: finite elements programs for Linux
  
   Date: Sun, 3 May 1998 14:07:55 +0200 (MET DST)
   From: Roland Smith, rsmit06@ibm.net
   
   To: berntsen@bkm.dtu.dk
   In response to your query in the Linux Gazette #28:
   
     I started talking to the ones buying it and my arguments stopped,
     when they said that one reason for using NT was that they should be
     running finite elements programs on them and that the frontier for
     those programs was now on the Windows platform. I don't know
     anything about that, so I am looking for info; should I accept
     their arguments or is it that he just does not know what can be
     gotten for Linux? Commercial Finite Element Method (FEM) programs
     are also in the searchlight!
     
   FEM has traditionally a UNIX domain. Most FE programs run on
   commercial unices. I only know of one free program for Linux: felt.
   You can find it at
   http://www-cse.ucsd.edu/users/atkinson/FElt/felt.html
   
   Hope this helps.
   
   Roland
     _________________________________________________________________
   
  Re: How to enable swapping
  
   Date: Sun, 3 May 1998 13:51:21 +0200 (MET DST)
   From: Roland Smith, rsmit06@ibm.net
   
   To: kng@HK.Super.NET
   In the Linux Gazette you wrote:
   
     My machine, which is a Pentium Pro with 64MB memory, reports no
     swap space being used. In procinfo, it always report 0K swap space.
     I did a fdisk on /dev/hda and verified that a 64MB partition of
     type Linux swap (83) is actually there. So why is the swap never
     being used ?
     
   Swapping needs to be started. This can be done with the `swapon'
   command.
   
   Normally there should be something like `/sbin/swapon -a' in the
   system initialization scripts. On my Slackware system it is in
   /etc/rc.d/rc.S.
   
   For this to work, you need to define the swap partition in /etc/fstab.
   Something like (on my box):

/dev/hda7    swap         swap    defaults   1   2

   Hope this helps.
   
   Regards, Roland Re: cd rom
     _________________________________________________________________
   
  Re: Slackware
  
   Date: Sun, 3 May 1998 14:30:59 +0200 (MET DST)
   From: Roland Smith, rsmit06@ibm.net
   To: letromb@tin.it
   
   In the Linux Gazette #28 you asked:
   
     Hello.I have the Linux Slackware 2.0.30 Walnut Creek.I installed it
     on a Pentium 200 MMX with a 24x CD-ROM. During the installation I
     had to write "ramdisk hdd=cdrom" for reading the CD-ROM, but after
     the installation Linux doesn't see the CD-ROM. I have an atapi
     CD-ROM, and when I tried to compile my kernel another time, I saw
     that atapi is the default !!! So I don't understand where is the
     problem . What can I do ?
     
   To use your CD-ROM, you must "mount" it, i.e. add it to your
   file-system.
   
   You will have to make sure that the iso9660 filesystem is supported in
   the kernel.
   
   Mounting is most conveniently done by first adding an entry into your
   /etc/fstab file like this:

/dev/hdb     /mnt/cdrom   iso9660 ro,user,noauto,unhide 1 2

   (Assuming your CD-ROM player is /dev/hdb) Create the directory
   /mnt/cdrom before mounting the CD! Put a CD-ROM in the drive and issue
   the command `mount /mnt/cdrom' to mount the CD.
   
   You will have to unmount the CD (`umount /mnt/cdrom') before you can
   open the drive!
   
   Hope this helps.
   
   Roland
     _________________________________________________________________
   
  May 2Cent Tips--about:mozilla
  
   Date: Wed, 6 May 1998 10:28:44 -0700 (PDT)
   From: David Mc Anulty, davemc@connectnet.com
   
   The tip of going to about:mozilla is incorrect. You do not have to
   click on Netscape's logo to get the new animation. The act of visiting
   about:mozilla does this.
   
   It lasts until Netscape is restarted. So if you like him, set
   about:mozilla as your home page.
   
   Dave
     _________________________________________________________________
   
  Re: Rebooting without logging in as root, 2c tips
  
   Date: Wed, 06 May 1998 09:25:13 +0200
   From: Hartmut Niemann, niemann@cip.e-technik.uni-erlangen.de
   
     An alternative I used once on a system that did *not* have enabled
     was to provide a special login that *just* did a shutdown. There is
     such a line in my /etc/passwd now that I didn't put there, so I
     guess it's from Red Hat two years ago.
     
   I had this shutdown login too. Normally it needs rood rights, i.e. UID
   0. But then I found out that su shutdown does not execute the login
   shell, i.e. the shutdown script. So everybody can become 'shutdown',
   which is basically 'root' with a different startup shell. Bad if this
   'shell' doesn't get executed ...
   
   For some time I have had 'shutdown' just SUID root, and now I'm back
   to Ctrl-Alt-Del performing a shutdown -h. (And then press Ctrl-Alt-Del
   again for a reboot.)
   
   Hartmut.
     _________________________________________________________________
   
  Re: Running an ATAPI ZIP drive
  
   Date: 05 May 1998 20:26:26 -0500
   From: Omegaman, omegam@cmq.com
   
   Steve Beach gives some interesting remarks and good advice for setting
   up an ATAPI ZIP drive. In it he says: First, the kernel:
   
     Do _not_ use the "IDE FLOPPY" option (officially the name is
     CONFIG_BLK_DEV_IDEFLOPPY ). This will work perfectly for reading
     and writing, but it will not work for ejecting.
     
   I recently bought a system with one of these units PRE-installed. I
   purchased a copy of Debian 1.3.1 on CD and was surprised to find "IDE
   Floppy" support compiled into the stock kernel. So, like Steve, I
   added necessary entries to my /etc/fstab to mount my ZIPs and away I
   went.
   
   However, I do not have the problem he's had with ejecting my ZIP
   disks. On the front of my drive is a status light that also functions
   as the eject button. It works fine. I surmise that Steve's problem is
   that he has no such button and requires a software-only eject method.
   
   One note of warning: I once ejected a standard floppy by pressing the
   drive's eject button when it was mounted causing a system panic and
   forced reboot. I don't know if the eject button on the ZIP is disabled
   in the same way as the eject button on a CDROM when it is mounted. I
   have no intention of finding out.
   
   Omegaman
     _________________________________________________________________
   
  Re: enabling swap space
  
   Date: Tue, 05 May 1998 04:44:22 -0300
   From: Diego Rodrigo, d.rodrigo@iname.com
   
   On issue # 28, Kevin Ng wrote :
   
     My machine, which is a Pentium Pro with 64MB memory, reports no
     swap space being used. n procinfo, it always report 0K swap space.
     I did a fdisk on /dev/hda and verified that a 64MB partition of
     type Linux swap (83) is actually there. So why is the swap never
     being used ?
     
   Tagging a partition with type 83 (Linux swap) is not enough. You kave
   to prepare it for swap with mkswap (see manual page) . Type:

        mkswap /dev/hdxx

   where hdxx is your swap partition. After that, you have to append a
   line in /etc/fstab saying this:

        /dev/hdxx       none            swap

   where /dev/hdxx is your swap partition, none is the mount point, and
   swap is the type of file system.
   
   With these changes, the next time you reboot, your swap space will be
   added to your system. The command that actually adds your swap space
   to the system is swapon (see man page, section 8), which is called
   from an init script at boot time. OK, I agree, Linux shouldn't be
   rebooted, (only when recompiling the kernel), so you can just type:

        swapon -a

   and you'll have your swap space.
   
   Diego Rodrigo - ARGENTINA
     _________________________________________________________________
   
  Re: problems using menus in X
  
   Date: Thu, 7 May 1998 11:45:01 -0500 (CDT) From: Michael Hammel,
   mjhammel@graphics-muse.org
   
   To: eijck@iri.tudelft.nl
   
     I'm having a problem with my menus in X. I can access all menus (by
     mouse), but the items of those menus which are WITHIN a "X-box" are
     not selectable, somehow. The menus I'm talking about are menus like
     the 'vt fonts', 'main options' and 'vt options' in the Xterm. Or
     the 'file' and 'page' menu of Ghostscript. If anyone has a
     suggestion on why I can select the menu but not menu item, please
     send me a mail. I'm using Debian 1.3.
     
   Check your NumLock key. It should probably be turned off for
   applications written in strict Xlib or Athena widgets, which appears
   to be the case with the applications you mention. Its not a strict
   rule, but many people had problems with my XPostitPlus program, caused
   by the use of the number keypad with applications like XCalc.
   
   Michael J. Hammel, The Graphics Muse
     _________________________________________________________________
   
  Music Typesetters
  
   Date: Tue, 12 May 1998 12:13:50 -0400 (EDT)
   From: Robert Tennent, rdt@qucis.queensu.ca
   
   Although I appreciated Bob van der Poel's review of MUP in LG28, there
   are some good free music notation systems that weren't even mentioned.
   First, a very good site to check out is the Lilypond home page at
   
   http://www.cs.ruu.nl/people/hanwen/lilypond/out-www/index.html
   
   This describes Lilypond (which is still under development) but also
   has links to many other music packages.
   
   One of these, musixtex, is IMHO the best free system available. It
   certainly isn't beta, but it is being extended and improved
   constantly. The input language is plain TeX, but there are some good
   pre-processors available (PMX, MPP, M-Tx, SceX, ABC2MTeX). The output
   quality is professional. Several arrangements I've set using musixtex
   have been published directly from my postscript files. Check out
   
   http://www.gmd.de/Misc/Music
   
   for links, downloads, documentation, examples, etc.
   
   Bob Tennent
     _________________________________________________________________
   
  BASH hostname completion: comment on tip in May '98 issue
  
   Date: Tue, 12 May 1998 08:58:18 -0500
   From: Justin Dossey, dossey@ou.edu
   
   The script John Taylor sent had a nice idea to it, but I must admit I
   didn't read it; Bash completes host names by a builtin function.
   
   Just as you would use to complete a filename, you can use ESC, @ to
   complete a hostname (if it is in /etc/hosts) and CTRL-X, @ to list all
   possible hostname completions based on /etc/hosts.
     _________________________________________________________________
   
  Re: xdm and depth
  
   Date: Tue, 12 May 1998 11:32:26 +0100 (IST)
   From: Caolan McNamara, Caolan.McNamara@ul.ie
   
     From: Denny berg, Denny@ele.kth.se
     Hi, I'm tired of starting my X-session with 'startx -- -bpp 16' to
     get 16 biplanes instead of the default 8. How do I get xdm to run
     with 16 bpp? If I use it now, it starts X with 8bpp on my Red Hat 5
     installation.
     
   under redhat in the file /etc/X11/xdm/Xservers
   
   there's a line

:0 local /usr/X11R6/bin/X

   change this to

:0 local /usr/X11R6/bin/X -bpp 16D

   and ta-da, thats it.
   
   Caolan McNamara
     _________________________________________________________________
   
  Re: Shutdown and Root
  
   Date: Mon, 11 May 1998 13:42:44 +0200
   From: Aaron Digulla, digulla@wi-pc44.fh-konstanz.de
   
   Another note to the 2cents Tip "Re: Shutdown and Root":
   
   I have a shutdown user, too, and this is what he looks like:
   
   In /etc/passwd:

    shutdown:x:6:0:shutdown:/home/shutdown:/bin/sh

   You'll probably have to adjust the user-id (here: 6).
   
   Then you create a home-dir which just contains this script as
   .profile:

------------------------ .profile ---------------------------------------
#!/bin/sh
trap "" SIGKILL SIGINT SIGQUIT

PATH=/bin

# List all users which are still logged on
/usr/bin/finger

echo
echo "Really shut down (y/N) ?"

read answer

# Every answer except "y" is no
if [ "x$answer" != xy ]; then
        answer=n
fi

if [ $answer = y ]; then
        echo 'The system will now shut down. You can turn the power'
        echo 'off when the message "System halted" appears'
        /bin/sleep 5
        ./halt
else
        echo 'Abgebrochen...'
        /bin/sleep 1
fi
------------------------ .profile ---------------------------------------

   Now just copy /sbin/halt to /home/shutdown/ and make it executable for
   this user (chown shutdown halt and chmod 700 halt).
   
   Aaron "Optimizer" Digulla
     _________________________________________________________________
   
  Printing with Linux
  
   Date: Sat, 09 May 1998 18:50:06 +1000
   From: Mitch Davis, mjd@alphalink.com.au To: AFAIZ@cstp.umkc.edu
   
     I've just bought a HP DeskJet 722C printer, but I couldn't get it
     to work. I asked around and everyone has answered that Linux does
     not support it - is it a Windows-only printer? If so, is it
     possible to write a driver for it? or does anyone know of where I
     can get my hands on the driver (if it's already been written, of
     course).
     
   In an effort to reduce the production cost of their low-end printers,
   HP has removed as much of the electronics from the printer as
   possible, and put the burden of turning commands into dots on the
   printer driver in the computer. Somewhat euphuistically, this is
   called the Printing Performance Architecture, a kind of less-is-more
   concept which I'm sure is big in the HP marketing Dept.
   
   All is not lost however. There's a guy who reverse-engineered the
   protocol, and has written a driver. You can find his page here:
   
   http://www.rpi.edu/~normat/technical/ppa/
   
   (I have not tried it, nor have I corresponded with him).
   
   I hope this helps you.
   
   Mitch.
   (I don't work for HP. Well Ok, I do, but further away from the bit
   that makes printers than you'd ever believe. I speak as an outsider)
     _________________________________________________________________
   
  RE: finite elements programs for Linux
  
   Date: Fri, 22 May 1998 09:39:29 -0700
   From: "James Gilb (p27451)", p27451@email.sps.mot.com
   To: berntsen@bkm.dtu.dk
   
     At the department where I am sitting they are planning to buy a
     PC-bar, and they intend to put NT on the machines. I would benefit
     from them putting Linux on them, since I could then use them for
     simulations overnight. ... I don't know anything about that, so I
     am looking for info; should I accept their arguments or is it that
     he just does not know what can be gotten for Linux? Commercial
     Finite Element Method (FEM) programs are also in the searchlight!
     
   There a some really neat FEM codes out there that are free or
   semi-free. Check out the Scientific Applications for Linux (SAL) page,
   sponsored by Kachina Tech at http:// SAL.KachinaTech.COM/
   
   Next, go to the INTERNET FINITE ELEMENT RESOURCES page at:
   
   http://www.engr.usask.ca/~macphed/finite/fe_resources/
   
   and check out the section on Public Domain FE Programs (I think FElt
   is way cool). Also, there may be some commercial vendors that support
   Linux as well, you should probably ask your vendors. I found Northwest
   Numerics and Modeling on the above page which sells a product called
   Zebulon on Linux. Also, some related software is also available on
   Linux, e.g. PV-WAVE (graphics), MATLAB, Mathematica, Maple.
   
   Finally, do a search of Linux and FEM software on your favorite search
   engine. (linux + FEM + software gave me 1085 hits on www.hotbot.com).
   
   As a postscript, the future of FEM doesn't depend on the OS it is used
   on. The real work is done in numerical code that never touches the OS,
   indeed an OS call in the middle of the deepest loops would cause a
   severe slowdown of the program. Some of the interfaces that you use
   for input, pre-processing and post-processing may be moving to NT, but
   there are still substantial packages available on the big iron. In any
   event, the current IA32 line from Intel is not a leader in
   double-precision floating point work, the current crop of workstations
   will blow it away in most floating point benchmarks. This is improving
   with the emphasis on multi-media, but the new chips will be very
   expensive within the near term (USD $2000-$4000 until at least 2000).
   
   If you have any more questions, please email me.
   
   James Gilb, p27451@email.mot.com
     _________________________________________________________________
   
  RE: How to enable swapping
  
   Date: Thu, 21 May 1998 15:49:17 -0700
   From: "James Gilb (p27451)", p27451@email.sps.mot.com
   To: kng@HK.Super.NET, gazette@ssc.com
   
     My machine, which is a Pentium Pro with 64MB memory, reports no
     swap space being used. In procinfo, it always report 0K swap space.
     I did a fdisk on /dev/hda and verified that a 64MB partition of
     type Linux swap (83) is actually there. So why is the swap never
     being used ?
     
   First, make sure the partition has been turned into a swap partition
   by doing an mkswap on it. Then just do swapon /dev/hda? where ? is the
   partition number of the swap partition. Now, if you put an entry for
   the swap partition in /etc/fstab and run swapon -a in your boot
   scripts (pretty early on), then swap will be automagically enabled
   whenever you boot.
   
   James Gilb
     _________________________________________________________________
   
  Cuckoo Clock
  
   Date: Sun, 24 May 1998 23:48:02 +0200
   From: Jjacobsen, jacobsen@biosys.net
   
   My wife's grandpa has a pretty switzer-cuckoo-clock (kuckucksuhr..).
   Well, I love to hear the little bird singing every hour. That's why I
   wrote this little script...

#!/bin/sh
#cockoo.sh
time=`date +%I`
count=0
until [ "$count" -eq "$time" ]
  do
   play /usr/share/sounds/au/cuckoo.au
   count=$[$count+1]
  done

   Then, I edited the crontab file using crontab -e:

00 * * * * /bin/cuckoo.sh

   and well, it's really funny... Using my script and cron, your Linux
   box will become a great switzer-kuckucks-uhr ;)
   
   Joerg Jacobsen, Schweinfurt, Germany
     _________________________________________________________________
   
               Published in Linux Gazette Issue 29, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
      This page maintained by the Editor of Linux Gazette, gazette@ssc.com
      Copyright  1998 Specialized Systems Consultants, Inc.
      
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                                 News Bytes
                                      
                                 Contents:
                                      
     * News in General
     * Software Announcements
     _________________________________________________________________
   
                              News in General
     _________________________________________________________________
   
  June Linux Journal
  
   The July issue of Linux Journal will be hitting the newsstands June 5.
   The focus of this issue is Science and Engineering with articles on
   using Linux at CERN, the NIST Neutron Lab and the British Antarctic
   Society. Also, an introduction to Samba and a look at two programming
   languages: Yorick and ICON. Check out the Table of Contents. To
   subscribe to Linux Journal, click here.
     _________________________________________________________________
   
  Corel & Open Source
  
   Corel and Corel Computer Corporation have announced their official
   position on Linux and Open Source Software. At the Ottawa Carleton
   Linux Users Group meeting, Corel announced that they will port all of
   their commercial applications to Linux, including a $99 version of
   Corel Word Perfect Suite 8. Corel Computer will open the source code
   for the development of their NetWinder NC.
   
   For more information:
   http://www.corelcomputer.com/
   http://www.corel.com/
     _________________________________________________________________
   
  Linus Torvalds & Richard Stallman at the USENIX Conference, June 1998
  
   Date: Thu, 7 May 1998 10:53:17 -0700 (PDT)
   Linus Torvalds, developer of Linux, and Richard Stallman, founder of
   the GNU project, will participate in the USENIX Annual Technical
   Conference, June 15-19, 1998, at the Marriott Hotel in New Orleans.
   
   This year the conference includes a special track showcasing the
   latest developments and interesting applications in FreeBSD, GNU,
   Linux, NetBSD, OpenBSD, Samba, and more. FREENIX offers 28 talks, plus
   evening BoF sessions. Share ideas and actual code with developers and
   avid users of freely redistributable software.
   
   Full program and on-line registration:
   http://www.usenix.org/events/no98/
   
   For more information: Jackson Dodd, jackson@usenix.ORG
   USENIX, the Advanced Computing Systems Association
     _________________________________________________________________
   
  O'Reilly's Perl Conference 2.0
  
   Date: Fri, 22 May 1998 09:47:48 -0700 (PDT)
   O'Reilly & Associates is presenting the Perl Conference 2.0 from
   August 17-20, 1998 at The Fairmont Hotel in San Jose, California. Perl
   Conference 2.0 features two days of intensive tutorial sessions
   followed by a two-day conference led by key Perl developers. Full
   program and registration information is at:
   
   http://conference.perl.com
   
   For more information:
   Ellen Elias, elias@ora.com
   O'Reilly & Associates
     _________________________________________________________________
   
  Linux Penguins Stickers
  
   Date: Sat, 23 May 1998 01:06:25 +0300 (EEST)
   Linux Penguin Sticker Movement announces printed Linux Penguin
   Stickers
   
   In cooperation with the Linux Penguin Sticker movement
   http://www.jyu.fi/~juhtolv/linux-sticker/ Linux Mall has agreed to
   make available professionally designed and printed Penguin Stickers
   for all who do not wish to print their own.
   
   For more information:
   http://www.LinuxMall.com/PP.html
     _________________________________________________________________
   
  Announcement and Call for Papers, 7th International Python Conference
  
   Date: Thu, 28 May 1998 18:29:07 -0400 (EDT)
   
   7th International Python Conference
   South Shore Harbour Resort
   Houston, Texas
   November 10-13, 1998
   
   For more information, visit the conference Web page at:
   
   http://www.foretec.com/python/workshops/1998-11/

IMPORTANT DATES:
June 29: email intent to submit paper
July 27: deadline for papers and tutorials
Aug. 31: notification of acceptance for papers
Sep. 28: deadline for final versions of full papers

   For more information about submitting a tutorial:
   http://www.foretec.com/python/workshops/1998-11/cft.html
   
   Jeremy Hylton, CNRI, jeremy@cnri.reston.va.us
   Program Chair, 7th International Python Conference
     _________________________________________________________________
   
  Linux Links
  
   Project MUSCLE: http://www.linuxnet.com/smartcard/index.html
   
   "Introduction to Linux" class:
   http://www.learningtree.com/us/courses/330.htm#top
   
   Linux Applications: http://www.linuxapps.com/
   
   Linux Advocacy: http://www.netnomics.com/linux/
   
   New Linux Help Page: http://www.admin.burned.org/
   
   Linux Links: http://www.linuxlinks.com/
   
   The Linux PenguinPlay Project: http://sunsite.auc.dk/penguinplay/
   
   ECLiPt Project: http://eclipt.uni-klu.ac.at/
   
   Linux Discussion Board:
   http://paradigm.uor.edu/linux/wishlist/bulletinboard.html
   
   Free Linux Support: http://support.marko.net/
   
   Current ports of Linux OS:
   http://www.ctv.es/USERS/xose/linux/linux_ports.html
   
   Linux Books: http://www.technologybooks.com/linux.htm
   
   Linux on-line bookstore: http://www.dragonfire.net/~garym/linux.html
     _________________________________________________________________
   
  Project Independence: Linux for the Masses
  
   Date: Tue, 12 May 1998 08:16:43 GMT
   
   A system accessible only to a minority will remain a minority OS.
   Project Independence believes that this is not an acceptable fate for
   Linux. Project Independence aims to make Linux accessible to people
   with little computing experience.
   
   A Call For Action:

*       If you want to make Linux usable
*       If you favour a pragmatic approach
*       If you believe in the bazaar model
*       If you are unhappy when you are unable to recommend Linux to
        friends and relatives,
*       If you want to act upon it

   Go straight to: http://independence.dunadan.com/
   
   For more information:
   Jean Francois Martinez, jfm2@club-internet.fr Linux Application
   Development Book Date: Tue, 12 May 1998 08:27:42 GMT
   
   New book available from Linux Central: Linux Application Development
   By Michael K. Johnson and Erik W. Troan from Addison Wesley
   Publishing.
   
   Linux Application Development helps C programmers write applications
   that run on Linux.
   
   For more information:
   sales@linuxcentral.com
     _________________________________________________________________
   
                           Software Announcements
     _________________________________________________________________
   
  Stalker Software Announces CommuniGate Pro Server 2.0 Beta
  
   Date: May 15th, 1998
   CommuniGate Pro 2.0 beta is the platform-independent Internet
   messaging server. The new generation of the CommuniGate integrated
   messaging system unifies the performance of multi-threaded operating
   systems, the standards-compliance of the Internet applications, and
   flexibility of the modular CommuniGate System, initially designed for
   MacOS.
   
   The new version of the CommuniGate Pro is based on the Stalker
   Foundation framework and can run under all major operating systems.
   The first released versions can run on the Linux operating system
   among others.
   
   The CommuniGate Pro server can be configured, controlled, and
   monitored from any computer connected to the Internet using any Web
   browser application. The administrators can monitor the Server status,
   create, update and modify user accounts, delete and redirect messages
   in the queues, update the communication modules settings, and
   configure the full-featured CommuniGate Router.
   
   SMTP component of the CommuniGate Pro server incorporates all the
   anti- spamming features implemented in the other Stalker mail servers,
   including centralized DNS-based blacklisting (RBL).
   
   The CommuniGate Pro server is scheduled for the commercial release in
   July'98. The beta versions of the CommuniGate Pro Server are available
   now, free of charge. They can be downloaded either from the Stalker
   sites:
   
   http://www.stalker.com/CommuniGatePro/
   ftp://www.stalker.com//pub/CommuniGatePro/
   
   For more information:
   Ali Liptrot, ali@stalker.com, http://www.stalker.com/
     _________________________________________________________________
   
  LPEvol, A Java Application
  
   Date: Wed, 20 May 1998 14:25:25 +0200 This is a first (beta) release
   of LPEvol, a Java application which allows you to interactiveley breed
   LSystems objects and view the results graphically. LSystems are
   (recursive) mathematical models that can be used to describe growth
   patters modelling the shapes we see around us every day, like trees,
   flowers and many others. LPEvol is an application which uses LParser
   and PovRay to generate and draw these LSystems. You as the user then
   have the choice to select the LSystems you like and then breed them
   (doing a crossover, using theGenetic Algortihm) to produce a next
   generation (the children ) which will have been derived from the
   formulas ( genes ) describing the parents.
   
   LPEvol requires:

- JDK 1.1.x
- lparser (default works; a modified lparser.c is shipped with LPEvol)
- PovRay 3
- cjpeg
- see the README file for other (hardware/memory) requirements.

   LPEvol 0.50 is available from:
   ftp://sunsite.unc.edu/pub/Linux/science/biology/
   http://www.peoplesoft.com/peoplepages/g/robert_gasch/src/src.htm For
   more information:
   Robert Gasch, Robert_Gasch@peoplesoft.com
     _________________________________________________________________
   
  RED HAT LINUX 5.1
  
   Date: May 26, 1998
   Red Hat Software, Inc. announced the June 1 release of Red Hat Linux
   5.1, a powerful update that includes enhanced installation features,
   as well as system configuring, web caching, window management features
   and an added value CD of applications for Linux.
   
   For more information:
   http://www.redhat.com/
     _________________________________________________________________
   
  Webmin version 0.51 - WWW-based configuration software
  
   Date: Mon, 4 May 1998 07:50:19 GMT
   Webmin version 0.51 is now available for download from
   
   http://www.webmin.com/webmin/
   
   This version allows the simple, browser-based configuration of Unix
   services such as

 - Apache (version 1.1, 1.2 and 1.3)
 - Samba
 - Crontab
 - NFS exports
 - BIND
 - Inetd
 - SYSV init scripts
 - Local/remote mounts and /etc/fstab
 - Users and groups
 - Disk partitions
 - Running processes
 - Disk quotas
 - Software packages
 - PPP accounts

   Webmin runs on Solaris 2.5 & 2.6, Redhat Linux 4 & 5, Slackware Linux
   3, Debian 1.3 and SUSE 5.1.
   
   For more information:
   Jamie Cameron, jcameron@webmin.com
     _________________________________________________________________
   
  banal 0.05 (bookkeeping software) released
  
   Date: Thu, 7 May 1998 12:50:51 GMT
   TITLE INFORMATION: BANAL 0.05 - or BANAL's Absolutely Not A Ledger
   AUTHOR INFORMATION: Matthew Rice - Matthew.Rice@ftlsol.com AFFILIATION
   INFORMATION: FTL Solutions Inc. DATE INFORMATION: May 1998
   
   BANAL is a bookkeeping system that allows you to track invoices,
   clients, projects, TODOs, bank accounts and expenses. BANAL is a
   client/server application so you can keep one set of books one your
   system while allowing everyone access.
   
   If you want to obtain BANAL and try it out, ftp to:
   ftp://sunsite.unc.edu/pub/Linux/apps/financial/accounting.
   
   and look for a file banal-X.YY.tar.gz, with X.YY being a version
   number (0.00 is of course the first). Unpack it in a "sources"
   directory and start reading the document in the "doc" subdirectory.
   
   FTL Solutions Inc. holds the copyright (I am doing it under their
   time), however, it is very unrestricted (read: do what you want but
   don't think of suing them). There is a more detailed COPYRIGHT file
   included with the distribution.
   
   For more information:
   Matthew Rice Matthew.Rice@ftlsol.com
     _________________________________________________________________
   
  satlas-0.95 (solar atlas) released
  
   Date: Mon, 4 May 1998 07:17:18 GMT
   I am announcing a first public release of satlas!
   
   Satlas is an electronic atlas of the solar sprectrum and targeted
   primaraly for astronomers who do a lot of spectral analysis work. It
   is based on Gtk+ and MySQL. MySQL is used to store, manage and provide
   a quick access to the data, while Gtk+ is provides GUI.
   
   http://www.physics.unc.edu/~serge/satlas/
   
   Satlas is distributed under GNU Public License.
   
   For more information:
   Sergei Naumov, serge@astro.unc.edu
     _________________________________________________________________
   
  ECLiPt Mirror 2.0b1 (former SimpleMirror)
  
   Date: Mon, 4 May 1998 07:34:37 GMT
   I've just released a new version of ECLiPt-Mirror (it's original name
   has been SimpleMirror). The new release includes

- - HTML-Logs, including the possibilty to directly download from this
  page
- - automatic creating of index-files as an overview over all mirrors
- - download just the most recent version of some files (e.g. the linux
  kernel)
- - bug fixes :-)
- - new bugs :-(

   Have a look at http://eclipt.uni-klu.ac.at (and then the mirror
   section) for a example usage. You can download it from the same page
   (under the projects section).
   
   For more information:
   Martin Preishuber, Martin.Preishuber@stuco.uni-klu.ac.at
     _________________________________________________________________
   
  Whisper 0.1 - Internet Telephone Application
  
   Date: Thu, 7 May 1998 12:32:21 GMT
   
   I announce the availability of Whisper -- Internet Phone. You can use
   it to talk to other people on the Internet. It uses gsm compression
   and should be suitable for low speed networks (19.200 bps and up)
   
   I uploaded the sources to /incoming/Linux on sunsite. Hopefully they
   will appear in /pub/Linux/apps/sound/talk. Sources (and a binary
   version) are also available at:
   
   http://www.itp.uni-hannover.de/~roeden/whisper.html
   
   Copying-policy: GPL
   
   For more information:
   Claus Roedenbeck, roeden@itp.uni-hannover.de
     _________________________________________________________________
   
  JCam 0.3 - Java-based software for Digital Cameras
  
   Date: Tue, 12 May 1998 08:05:54 GMT
   JCam - a single software program for (almost) all OSes and (almost)
   all Digital Still Cameras ...
   
   Release 0.3 of JCam, available from http://www.jcam.com introduces
   support for cameras from Fuji and Olympus ... this adds to existing
   support for cameras from Epsom, Casio, Kodak ... and a neater user
   interface with "LEDs" ... ;-)
   
   For more details about supported cameras, etc, please E-Mail to
   info@jcam.com or visit the Web Page at "www.jcam.com" ... For more
   information:
   info@jcam.com, http://www.jcam.com/
     _________________________________________________________________
   
  gax 1.0 - galaxy DB utility for astronomy
  
   Date: Tue, 12 May 1998 08:14:06 GMT
   Announcing the first release of Gax, a program for amateur astronomy.
   
   Gax can create searchable databases of galaxy information that can
   then be searched based on user selectable ranges for fields in the
   database.
   
   The information contained in or derived from the database includes:

        RA
        Declination
        Major/Minor Diameter
        Position Angle
        Magnitude
        Surface Brightness
        Constellation
        Uranometria 2000 Map number
        Local Transit Time

   Report formatting is also under complete user control providing the
   ability to tailor the report output to your specific needs.
   
   Temporarily at: http://sunsite.unc.edu/pub/Linux/Incoming/
   
   Permanite site: http://sunsite.unc.edu/pub/Linux/science/astronomy/
   
   Files: 1664Kb gax-1.0.tar.gz, 1Kb gax.lsm
   
   Copying-policy: GPL
   
   For more information:
   Mark Anderson, manders1@csc.com
     _________________________________________________________________
   
  SampLin, new scientific data acquisition software
  
   Date: Tue, 12 May 1998 08:15:10 GMT
   Few days ago I released first public version of scientific data
   acquisition software 'SampLin' which can be found at
   http://www.troja.mff.cuni.cz/~kvasnica/samplin.html.
   
   Currently is implemented support for serial, gpib devices and
   arbitrary labcards with drivers, basic-like script language and simple
   plot widget. Software supports data acquisition over TCP/IP network
   via RPC protocol from remote servers. Requirements: X11R6, Qt, KDE
   libs, GPIB lib
   
   *** I'M LOOKING FOR NEW PROGRAMMERS TO CONTINUE THIS PROJECT ***
   
   For more information:
   Samuel Kvasnica, kvasnica@iaee.tuwien.ac.at
     _________________________________________________________________
   
  SCNN3.3 cellular neural network simulator
  
   Date: Tue, 12 May 1998 08:33:00 GMT
   The new version of our simulation system for cellular neural networks
   (CNN) is now available from our home page
   http://apx00.physik.uni-frankfurt.de/e_ag_rt/cnn/SCNN/
   
   It is a zero price product, available for Intel x86 (Linux), IBM RS
   6000 (AIX4), SGI Indigo (Irix 6.2), HP (HP Unix) and DEC Alpha
   (Ultrix). It is planned to add versions for other Unix operating
   systems on request. For more information take a look at our homepage.
   
   For more information:
   SCNN Team, Roland Kunz, kunz@apx12.physik.uni-frankfurt.de
     _________________________________________________________________
   
  Sox 12.14 - Universal Sound Processing Tool
  
   Date: Fri, 15 May 1998 07:40:31 GMT
   The latest patchlevel of Sox is now available. Sox is intended to be
   the Swiss Army knife of sound processing tools. Its allows a user to
   convert sounds files between any supported format including CD Audio,
   .au, .voc, .wav and several others. Latest versions also include
   support for playing the sound file to either Linux's /dev/dsp or a Sun
   /dev/audio.
   
   It can be downloaded from the following sites:
   
   http://home.sprynet.com/sprynet/cbagwell/projects.html
   http://sunsite.unc.edu/pub/Linux/apps/sound/convert/sox-12.14.tar.gz
   
   For more information:
   Chris Bagwell, cbagwell@fujitsu-fnc.com
     _________________________________________________________________
   
  Linux Point Of Sale
  
   Date: Mon, 18 May 1998 11:16:14 GMT
   LinuxPOS Version 1.0 Released for Beta Testing
   
   Linux Canada Inc. wishes to announce that the beta version of LinuxPOS
   1.0 is now available for evaluation. LinuxPOS is an exciting new point
   of sale application written in Tcl/Tk. If you require the
   power,stability and connectivity of Linux, the graphical user
   interface inherent in Tck/Tk, a dynamite point of sale application and
   full source code for peace of mind and/or personal customizations ---
   then LinuxPOS is for you.
   
   For more information:
   Philip Tonellier, phil@linuxcanada.com, http://www.linuxcanada.com/
     _________________________________________________________________
   
  SHAREWARE: QuoteGrabber-1.0 Real-time stock quotes.
  
   Date: Tue, 26 May 1998 12:47:06 GMT
   The QuoteGrabber, 1.0.0 is a universal stock market client.
   
   A stock market tracker and portfolio manager written in Java and
   developed under Linux, the QuoteGrabber provides real-time and delayed
   quotes, news and charts. Fully customizable, it is a versatile tool:

- - trading: real-time quotes for www.datek.com clients and registered
  users;
- - charting: intra-day, 3 month, 1 year, 2 years, 5 years;
- - news: breaking company news as they arrive;
- - portfolio management: enter all transactions, track portfolio
  performance;
- - alerts: based on a combination of four criteria;
- - international stocks: US, Canada, France, UK, Germany, Italy (delayed
  15-20 minutes);

   The QuoteGrabber is distributed as 30-day trial shareware with a
   personal license price of $25.
   
   For more information:
   Louis-David Mitterrand, mito@aparima.com,
   http://www.aparima.com/quote/
     _________________________________________________________________
   
  Fortify now on Linux_glibc2: 128-bit Netscape crypto
  
   Date: Tue, 26 May 1998 13:01:39 GMT
   Sydney, Australia. (23 May, 1998). By popular demand, Fortify for
   Netscape has now been extended to support the Linux_glibc2 editions of
   the Netscape web browsers (Communicator and Navigator v4.05).
   
   This functionality is available immediately, as part of the
   Fortify-1.2.3-unix distribution. You can download this from the
   Fortify web site, at http://www.fortify.net/
   
   In a second addition to the Fortify service, the Fortify-announce
   mailing list is now on-line, and open to anyone who wishes to receive
   news and announcements via e-mail regarding the Fortify project. You
   can subscribe to the mailing list here:
   http://www.fortify.net/feedback.html
   
   Farrell McKay, fbm@jolt.mpx.com.au
     _________________________________________________________________
   
  Organic molecule drawing program
  
   Date: Tue, 26 May 1998 13:30:46 GMT
   I have written a program to draw organic molecules easily under X. You
   can store the picture as bitmapfile. It is compiled with the Athena
   Widget Set and is also compartible to UNIX.
   
   You can download the sourcecode at:
   
   http://www.uni-ulm.de/~s_tvolk/chemtool.html
   
   copyright is GPL
   
   For more information:
   Thomas Volk, thomas.volk@student.uni-ulm.de,
   http://www.uni-ulm.de/~s_tvolk/
     _________________________________________________________________
   
  Toshiba Linux Utilities
  
   Date: Tue, 26 May 1998 13:43:46 GMT
   The Toshiba Linux Utilities are a series of three programs that I have
   written to replace Toshiba supplied MS-DOS or Microsoft Windows
   programs for controlling Toshiba laptops, with Linux versions. Full
   details and source code can be found at
   
   http://www2.prestel.co.uk/hex/toshiba.html
   
   FAN: A update to my fan program that uses a completely new version of
   turning the fan on/off. If you have tried a 1.x version of the program
   and it did not work on your laptop try this version. This version is
   known to work on the new Satellite Pro models (440x, 460x, 480x), and
   may work on others that the previous version did not. I am
   particularly keen to hear from owners of Tecra's.
   
   SVPW: A direct replacement for the svpw.exe program found on the
   Companion diskette, for the setting/removal of supervisor passwords,
   and changing whether setup can be run in user mode. Known to work on a
   Satellite Pro 400x, 430x, and 440x. I am keen to know if it works on
   other models.
   
   To anyone reading this, svpw does not, and cannot be made to remove
   passwords unless you already know the password. This is not a
   limitation impossed by me. I don't know how to *crack* the passwords
   on Toshiba laptops and have no interest in doing so. I will not answer
   any emails relating to this.
   
   HOTKEY: This is not exactly a replacement for a Toshiba program, but
   provides the same functionality as MaxTime(tm) does under Microsoft
   Windows, under X11 when the power-up or battery save mode is changed
   with the Fn+F2, Fn+F3 key combinations. Namely a small window pops up
   in the centre of the screen with some icons to let you know what you
   are doing. It is know to work on a Satellite Pro 400x, 430x, Portage
   610x, and Tecra 740x
   
   For more information:
   Jonathan A. Buzzard, jab@hex.prestel.co.uk 
     _________________________________________________________________
   
  GNU Midnight Commander 4.1.35 file manager
  
   Date: Tue, 26 May 1998 14:11:12 GMT
   The Midnight Commander team has just released version 4.1.35 of the
   GNU Midnight Commander. For more information on the Midnight
   Commander, please consult
   http://www.gnome.org/mc
   
   This program is available now in:
   
   ftp://ftp.nuclecu.unam.mx/linux/local/mc-4.1.35.tar.gz
   
   For more information:
   Miguel de Icaza, miguel@nuclecu.unam.mx
     _________________________________________________________________
   
               Published in Linux Gazette Issue 29, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
      This page written and maintained by the Editor of Linux Gazette,
      gazette@ssc.com
      Copyright  1998 Specialized Systems Consultants, Inc.
      
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                           (?) The Answer Guy (!)
                                      
                   By James T. Dennis, answerguy@ssc.com
          Starshine Technical Services, http://www.starshine.org/
     _________________________________________________________________
   
  Contents:
  
   (!)Greetings from Jim Dennis
   
   (?)Version-a-go-go and the Tragedy of being "Left Behind"
          
   (?)Removing Lilo from a multi-boot machine
          
   (?)Question on sendmail... --or--
          'sendmail' FEATURE creatures for virtual domain and generic
          re-write tables
          
   (?)Kernel crashes
          
   (?)Winmodems --or--
          More on 'WinModems': How to "lose" Gracefully - Just say No!
          
   (?)Mail on a LAN Linux to NT --or--
          Basic e-mail Setup for Linux?
          
   (?)Remote Tape Backups
          
   (?)adduser
          
   (?)Letter to Dell - Linux on Dell Hardware
          
   (?)Hello --or--
          Connecting a Dumb Terminal to your Linux System
          
   (?)Why Linux?
          
   (?)Redhat telnet
          
   (?)Network Cards
          
   (?)A little note about "good times" or emailed viruses --or--
          "Good Times" are Spread to the "Great Unwashed"
          
   (?)The Answer Guy --or--
          Regarding the Column's New Look
          
   (?)TACACS+ client for Linux --or--
          TACACS and RADIUS Authentication Models for Linux and/or PAM
          
   (?)Sendmail jam --or--
          'sendmail' Log Jams and Capacity Problems: running extra
          'sendmail -q' processes
          
   (?)PPP connection and diald --or--
          Co-ordinating diald and Manual PPP
          
   (?)getting ppp-2.3.3 to work
          
   (?)Mail access --or--
          Getting at MS-Mail from within Linux: The Myriad Ways to
          Co-exist with MS Windows
          
   (?)Program for Mailer Daemons --or--
          Automated Handling for MAILER-DAEMON Messages: Read The
          Sources, Luke.
     _________________________________________________________________
   
Linux Gazette: The Answer Guy for June, 1998

   The theme for this month seems to be "vendor support for Linux." From
   the responses to my open letter to Dell, through the common problems
   with "winmodems" and "winprinters" and even to the impossible dream of
   running MS Windows applications and accessing Microsoft proprietary
   formats from native Linux applications --- we continue to fight uphill
   battles with so many vendors.
   This isn't new in the broader Unix world. Readers of A Quarter Century
   of Unix by Peter H. Salus should recognize this as a as an attitude
   that has dominated hardware vendors for almost thirty years. They've
   been prdicting the "death" of Unix (and the "death of the Internet)
   almost since from the beginning.
   There is some hope on the horizon. As some of you may have heard or
   read corelcomputing (the hardware division of the famous software
   company) is basing it's NC (network computer) on a Strong-ARM version
   of Linux. Within a week or two after that Corel Software announced
   their intention of porting the rest of the applications suite to Linux
   (their WordPerfect 7 and 8 have been available in Linux versions for
   some time).
   A little further afield it appears that Apple Inc is starthing to make
   some sense with their future OS strategy --- by "thinking different",
   or "outside of the box" in a manner of speaking. Specifically they've
   apparently decided to skip the planned version of Rhapsody with its
   "blue" and "yellow" boxes that separated the MacOS and the
   Mach/NeXTStep (Unix) personalities. Apparently buried in their
   announcement for MacOS X ("ten") is the i rumor that your "NeXT"
   (Rhapsody) native applications will co-exist on the same desktop with
   yor MacOS programs --- and that the MacOS API's will be seamlessly
   supported with all the multi-threaded support that the Mach
   microkernel can provide. Of course you have to hear that as rumors, or
   read between the lines with a considerable background in the Macintosh
   architecture since it is not apparent from their own press releases,
   or from the San Jose Mercury News articles on the subject. The San
   Francisco Examiner sings a similarly hollow tune. However, I'm not
   alone in my opinion as we see in David K. Every's article.
   I suspect he knows way more than I do on the subject.
   Oddly the MacOS Rumors web site seems to have no mention MacOS X on
   their site.
   What does this have to do with Linux? Well, I can only continue to
   speculate that mkLinux binaries will eventually run under MacOS X
   (Rhapsody). I can also still hope that, with the progress in the G3's,
   and the plans for the G4 generations of the PowerPC platform, and
   hopefully the continued availability development of the DEC (Compaq)
   Alpha processor, we'll see some real choices and competition in the
   market place. Linux is the one OS that crosses all of these (and Sun
   SPARC's and SGI MIPS and others). Some form of Unix is available on
   just about every platform, whether or not it supports Linux.
   As we look beyond the world of PC clones we see that there is some
   vendor support. There is some hope that Microsoft's legacy will be the
   separation of hardware vendors from their "control" hegemony. Before
   Microsoft it was the norm for computer manufacturers to almost
   completely control the availability of software for their platforms
   --- Unix has undermined that control for over two decades. The popular
   backlash from Microsoft's own unique form of control --- over the
   collective Wintel platform --- may finally completely sever the
   puppet's strings. The trickles of vendor support that you're seeing
   now is largely a survival strategy. So not only will these vendors
   give up the efforts to control their customer's range of software
   choices, they'll be glad they did it, considering the alternative.
   _______
   
   Jim Dennis
     _________________________________________________________________
   
                     Copyright  1998, James T. Dennis
               Published in Linux Gazette Issue 29 June 1998
     _________________________________________________________________
   
   [ Table Of Contents ] [ Front Page ] [ Back ] [ Next ]
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                    GUI building using the Java 1.1 AWT
                                      
                     Java Linux Audio CD Player--Part 2
                                      
                            By Michael Hamilton
     _________________________________________________________________
   
  Contents:
  
     * The Player Class
     * The Form Panel
     * The Menu Bar
     * AWT Adapters
     * The Main Button Control
     * The CD Player Status Display
     * The SmartDrive and the Monitor Thread
     * The Program Window
     * Summary
     * Resources
     _________________________________________________________________
   
   In my previous article I described a simple CD player that can be
   extended to create a GUI player such as Jcd, a freeware player I've
   made available on the Web, see
   http://www.actrix.gen.nz/users/michael/giveaways.html
   
   In this article I will describe how to extend the Drive object so that
   it can carry out programmed play (play a list of tracks) and shuffle
   play (play every track once in a random order). The structure of the
   new player is described by the class diagram in the following figure.
   Rather than starting with the low level components, I thought it would
   be more interesting to start with a description of the GUI interface.
   For the moment just assume that there is a new SmartDrive version of
   Drive that includes all the old functionality, plus monitoring of the
   Drive state and the ability to accept and modify a list of tracks to
   be played. I'll introduce the use of the new functionality as we
   proceed.
   
   [INLINE]
   
   In my previous article I described a Java class, called ``Drive'',
   that provides the following CD player functionality:

Drive Object:
        Informational methods:
                currentTrack, currentIndex, numberOfTracks,
                currentAddress,
                cdEndAddress, trackAddress, trackLength

Control methods:
        play, stop, pause, resume, eject, setVolume

   In this article I will describe how to extend the Drive object so that
   it can carry out programmed play (play a list of tracks) and shuffle
   play (play every track once in a random order). But rather than start
   with the low level components, I thought it would be more interesting
   to start with a description of the GUI interface. For the moment just
   assume that there is a new SmartDrive version of Drive that includes
   all the old functionality, plus monitoring of the Drive state and the
   ability to accept and modify a list of tracks to be played. I'll
   introduce the use of the new functionality as we proceed.
   
   Since writing my previous article, the Java Development Kit 1.1 has
   been ported to Linux. This code in this article will use features of
   the AWT from JDK 1.1. The article was originally written using the JDK
   1.0.1, and the original JDK 1.0.1 code is included in the tar
   available at SSC's Linux Journal ftp site.
     _________________________________________________________________
   
  The Player Class
     _________________________________________________________________
   
   The new CD player I'm going to describe is called Player and is run
   from the command line by entering:

setenv SBPCD 1 # if you have an old SoundBlaster connected drive
java Jcd.Player

   Running the application creates the GUI interface in Figure 1 and
   Figure 2.
   
   The source code for the Player class is presented in Listing 1. The
   Player class has a static main() method on line 30, which is where
   program execution will begin. On line 32 the main() method creates an
   instance of the player class:

Player player = new Player();

   On lines 38 to 43, the Player's class constructor sets up the
   SmartDrive object that communicates with the CD player. The name of
   the device to open (/dev/cdrom) and the location of the native module
   (Jcd_Drive.so) is hard coded into the Player's constructor. The native
   module implements the kernel interface to the CDROM drive. In a real
   production version of the system, these parameters would be read from
   a configuration file or deduced by interrogating the operating
   environment.
   
   As previously stated SmartDrive is an extended version of the hardware
   interface class described in my first article--it has been enhanced to
   support programmed play, and to provide notification events concerning
   the CD players status. On line 56, the Player's constructor starts the
   SmartDrive's monitor. The monitor will begin delivering CD player
   events to any object that has registered for them.
   
                                  [INLINE]
                                      
                          Figure 1. GUI Components
                                      
   I'll now go back over Player and look at some of the code involved in
   the GUI. On lines 45 to 54 of Listing 1. the Player's constructor
   creates the GUI components seen in Figure 1: a menu-bar; a display
   area for track info; and a control area of push-button CD player
   controls.
     _________________________________________________________________
   
  The Form Panel
     _________________________________________________________________
   
   The AWT GUI toolkit provides components such as text-labels,
   text-entry fields, menus, and buttons. Components are placed into
   containers to build windows and pabels. The AWT's top level component
   container is the Frame class. A Frame constructs a separate
   free-standing window. Like other GUI toolkits, the AWT provides the
   programmer with sub-container classes that can be used to control
   component placement by subdividing a window into smaller areas. The
   AWT's major sub-container is the Panel class. The AWT provides further
   control over placement by allowing the programmer to configure a Frame
   or Panel's layout policy. For example, the standard AWT FlowLayout
   just places components left to right, top to bottom. A Frame or
   Panel's layout can be assigned from the layouts provided by the AWT or
   you can write your own.
   
   On line 10 of Listing 1, the Player class is declared to extend the
   Form class. The source code for Form is presented in Listing 2. Form
   is a class I've created that extends the normal top level AWT Frame
   class. Player is a Form, a Form is a Frame, a Frame creates a
   free-standing window, so Player creates a free-standing window. The
   Form class uses the AWT GridBagLayout manager. The GridBagLayout
   manager is the AWT's most flexible layout manager. It has a wide
   variety of options for the spacing, and placement of objects with a
   Frame or Panel. GridBagLayout's flexibility makes it complex to deal
   with. Form simplifies dealing with the GridBagLayout by providing an
   addCenter() method. On lines 23 to 32 of Listing 2, the addCenter()
   method controls placement by placing the object at the next available
   row and making it consume the entire row:

c.gridx = 0;
...
c.gridwidth = GridBagConstraints.REMAINDER;

   It sets fill to NONE. It sets the inset space around the component to
   1. The end effect is that the Form sub-class will place objects top to
   button, one object per row, each consuming the space it needs plus a
   little surrounding space.
     _________________________________________________________________
   
  The Menu Bar
     _________________________________________________________________
   
   Returning to the Player class. On lines 46 and 47 of Listing 1, the
   Player's constructor sets up the windows menu bar:

setMenuBar(new MenuBar());
getMenuBar().add(createFileMenu());

   The actual drop-down menu is created by the createFileMenu() method on
   Lines 70 to 78 of Listing 1. It creates the player's file-menu, and
   adds individual menu items to it. Lines 76 and 77 of createFileMenu()
   setup the event handling for the menu:

fileProgramItem.addActionListener(this);
fileExitItem.addActionListener(this);

   These two lines set up the Player object (this) to handle the
   ActionEvents from the file-menu's fileProgramItem and fileExitItem.
   These events are generated when the user selects a menu item. In order
   to be able to handle these events the Player class must implement the
   ActionListener interface--it is declared as such on Listing 1 line 10:

public class Player extends Form implements ActionListener

   What's going on here? Player inherits from--``extends''--Form, but
   what does ``implements ActionLister'' mean? Player can only inherit
   data and method definitions from a single parent--Java doesn't support
   multiple inheritance--an object can only ``extend'' one parent class.
   However, to provide some of the functionality of multiple inheritance,
   Java provides the ``implements/interface'' mechanism. In other
   languages multiple inheritance has to deal with the issue of what to
   do when a class inherits two more implementations of the same
   data-structure or method from two different parents. For example, say
   both parents have an add() method, which one should be used in the
   sub-class? Java's limited multiple inheritance mechanism, the
   ``interface'', doesn't support the inheritance of implementation.
   Except for class-wide constants, interface definitions must be
   completely abstract. An interface definition, such as ActionListener,
   cannot provide an implementation of any of the methods it declares.
   Any class wishing to ``implement'' an interface must provide its own
   code to implement all the methods in the interface. A class can
   implement any number of interfaces--a class could implement both
   ActionListener and MouseListener and handle both kinds of events. By
   not providing an implementation, interfaces leave conflict resolution
   in the hands of the programmer designing the implementation.
   
   Listener interfaces such as ActionListener, MouseListener, and others,
   were newly introduced in JDK 1.1. The new JDK 1.1 AWT Event model uses
   the Java interface mechanism to provide a more flexible event handling
   mechanism that the earlier version of the JDK. There are separate
   interfaces for different kinds of events such as the mouse or the
   keyboard. Multiple objects can register for the same events and they
   will all receive them.
   
   In order to implement the ActionListener interface, the Player class
   has to have an actionPerformed() method--the method is defined on on
   Lines 59 to 68. The Player will be passed menu events via a call to
   the actionPerformed() method. The actionPerformed() method checks
   which component was the source of the event and invokes an appropriate
   code fragment: at lines 62 to 65, the Player's actionPerformed method
   checks if the source of the event was the fileProgramItem--if it was,
   and there isn't an existing program showing, a new one is created. At
   line 66, if the source of the event was fileExitItem the program is
   terminated.
     _________________________________________________________________
   
  AWT Adapters
     _________________________________________________________________
   
   In some cases the interface necessary to handle an AWT event is quite
   complex. To save the programmer the work of having to completely
   define all of an AWT event interface, the AWT includes pre-written
   Adapter classes that provide default implementations for the more
   complex event interfaces. For example the MouseListener interface has
   a corresponding MouseAdapter class that provides a default
   implementation. These pre-canned AWT Adapter classes can be
   sub-classed to selectively override any of their methods.
   
   The Player class makes use of an Adapter class to handle close
   requests from the window manager. Close requests are usually the
   result of the user double clicking the close button on window's title
   bar. On line 52 of Listing 1, the Player registers a WindowListener:

addWindowListener(new DoClose());

   The WindowListener interface has several methods and I only want to
   override one of them--the windowClosing() method. Unfortunately the
   Player class can't inherit from the default WindowAdaptor class
   because the Player class already inherits from the Form class. The
   solution I've applied in this case is to use another new feature of
   the JDK 1.1. JDK 1.1 adds Inner Classes to the Java language--this
   means I can declare a class within a class:

public class Player extends Form implements ActionListener {
...
addWindowListener(new DoClose());
...
private class DoClose extends WindowAdapter {
public void windowClosing(WindowEvent e) {
System.exit(0);
}
}
...
}

   The Player uses addWindowListener() to register a new instance of its
   own inner DoClose class. Because DoClose is an Inner Class of Player
   it has access to Player's data and methods and can therefore be more
   closely integrated into Player than a separately declared class. In
   other languages it's quite common to solve situations such as this by
   passing pointers to methods, functions, or code-fragments--but in Java
   only objects can be passed, so Inner Classes were provided as one
   solution.
     _________________________________________________________________
   
  The Main Button Controls
     _________________________________________________________________
   
   Turning now to the remainder of the Player GUI interface: the Controls
   and Display classes. I'll describe the Controls class first because
   it's the simplest. Controls is a panel of buttons which you can see on
   the bottom of Figure 1. Listing 3 shows the source code for the
   Controls class. Since it is intended to be a sub-panel of Player it
   inherits from Panel:

class Controls extends Panel implements ActionListener

   The Controls class also needs to take action when the buttons are
   pressed, so it also implements the ActionLister interface.
   
   Lines 17 to 22 of Listing 3 declares the set of buttons. The button
   declarations also specify how to initialize the buttons when a
   Controls object is created. On lines 26 to 32, the Controls
   constructor adds each of the buttons to the Panel. The simple
   GridLayout manager, not to be confused with the more complex
   GridBagLayout manager, is used to control component placement within
   the Panel. GridLayout places components left to right, top to bottom,
   in equal sized cells in the grid specified:

setLayout(new GridLayout(1, 6, 2, 2));

   In this case the grid is 1 row by 6 columns--a column for each button.
   The last two arguments specify a horizontal and vertical gap between
   grid cells of 2.
   
   The Controls add() method, on lines 31 to 34, overrides the add()
   method inherited from the Panel super-class. Add() behavour has been
   modified to set the Controls object as the ActionListener for each
   button:

private void add(Button b) {
b.addActionListener(this);
super.add(b); // Now call super class add() method.
}

   The Controls actionPerformed() method, lines 36 to 49, reponds to
   button press events by invoking corresponding CdPlayer methods.
     _________________________________________________________________
   
  The CD Player Status Display
     _________________________________________________________________
   
   The final part of the interface shown in Figure 1 is the Display
   panel, the source code for which can be seen in Listing 4. The Display
   panel consists of three text fields to display the CD track, the CD
   index, and the CD track time remaining--trackField, indexField, and
   timeField. They're declared on lines 13 to 15 of Listing 4 and will be
   initialized as new TextFields a Display object is created (which only
   ever happens once in this application).
   
   The Display() constructor method is on line 20 of Listing 4. Lines 22
   to 29 setup the basic components involved in the display. The Panel is
   assigned the FlowLayout manager which means that calls to the add()
   method will place the three text fields in a left to right layout
   butted up to each other with a small amount of separation top and
   bottom. And on Lines 23 and 24 I've made the indexField and timeField
   read-only so the user can't alter their values:

 indexField.setEditable(false);
 timeField.setEditable(false);

   The trackField is left editable so that the user can enter the number
   of a track to start playing from. In order to handle the trackField's
   mouse focus events and keyboard events, we have to register a couple
   of event Listeners:

trackField.addFocusListener(new TrackFocusLost());
trackField.addKeyListener(new TrackKeyPress());

   Both of the Listeners are quite complex, so rather that write our own
   complete implementations, two default Adapter classes are sub-classed
   to handle the task on lines 53 to 74--more about them later.
   
   On line 34 we register Display() as an Observer of the cdPlayer:
cdPlayer.monitor.addObserver(this);

   The status of the CD player is actually kept track of by a Monitor
   object--the cdPlayer.monitor object. The monitor runs in its own
   thread (a thread can be thought of as a light weight sub-process that
   has shared access to the data of the main task). The need to monitor
   events and notify other objects is a common programming problem. Java
   provides the Observable Class, and its companion Observer Interface,
   as a standard basis for addressing this kind of problem. The monitor
   object is a sub-class of a Observable class. The Observable class
   provides the code necessary to manage the Observer/Observable
   relationship. The monitor class will be described in more detail
   later. Display is declared to implement Observer, which means it must
   define an update() method. The update() method will be called when an
   Observable event takes place. Display's update() method is defined on
   lines 37 to 51, it is passed the Observable object that caused the
   event and an extra argument (which isn't used in this application).
   
   Normally the trackField is updated once a second when the monitor
   broadcasts a status update to its Observers. The user can also alter
   the value of the trackField by entering a new track which will force
   the player to skip to it immediately. To prevent the one second update
   from clobbering the users input, the update() method is careful not to
   update the trackField text unless the track really has changed:

if (prevText.compareTo(newTrackText) != 0) {
trackField.setText(newTrackText);
prevText = newTrackText;
}

   Lines 53 to 75 of Listing 4 define two inner classes to handle user
   input into the trackField. TrackFocusLost restores the correct track
   number when ever the user changes focus out of the trackField. The
   inner class TrackKeyPress checks every key pressed in the trackField
   for the enter key. If enter is pressed, an attempt is made to parse
   the text entered into an integer value, if this succeeds the cdPlayer
   is instructed to immediately start playing at this track.
     _________________________________________________________________
   
  The SmartDrive and the Monitor Thread
     _________________________________________________________________
   
   Before we go on to describe how to write a GUI for programmed track
   play and shuffle play, we really have to understand more of the new
   SmartDrive class that extends the Drive class from my first article.
   SmartDrive.java can be seen in Listing 5. SmartDrive is a sub-class of
   the original Drive class. SmartDrive mainly adds new methods to
   provide for playing a list of tracks.
   
   In order to store the playlist of tracks, a new class called TrackList
   is defined at lines 175 to 243. TrackList is a sub-class of the JDK
   Vector class. A Vector is is a JDK implementation of a list-like
   structure. A Vector can only store java Objects. I would like to store
   int-type track numbers, but the int-type isn't a Java Object, it's a
   primitive data-type and primitive data types aren't first-class
   objects. To get around this problem the JDK provides a class wrapper
   for each kind of primitive data type. In this case I have to use the
   Integer wrapper class to contain each track number. When ever a track
   is added to a TrackList, the code actually stores a corresponding
   Integer object:

addTrack(int t) { addElement(new Integer(t)); }

   TrackList provides methods to test the state of the list, to advance
   along the list, and to reset the list. Because Vectors store generic
   Objects, TrackList also has to do a fair bit of casting. For example,
   elementAt() returns an Object that has to be cast to an Integer before
   I can use it:

Integer elem = (Integer) (elementAt(position)); // Cast Object to Integer

   The methods within TrackList have been declared as synchronized. This
   prevents multiple threads from simultaneously trying to access the
   same TrackList object. For example, we don't want the GUI to attempt
   to clear the track list at the same time as the cdPlayer attempts to
   advance to the next track in the track list. By declaring the methods
   as synchronized we ensures that requests are handled one at a
   time--waiting calls will block until the object is available.
   
   In order to implement programmed play, the SmartDrive class includes
   an instance of TrackList, called tracksToPlay. SmartDrive methods such
   as next() and prev(), on lines 53 to 83, either just play tracks in
   the normal numerical sequence, or in the order returned by the
   tracksToPlay nextTrack(), prevTrack() methods.
   
   Anytime the player gets to the end of track SmartDrive has to refer to
   tracksToPlay and issue a new play() call to play the next track in the
   program. In order to do this it sets up an instanse of the Monitor
   object mentioned earlier.
   
   2b:The code for the Monitor class is in Listing 6. As described
   earlier the monitor object is a sub-class of a Observable class, a JDK
   class that provides much of the code necessary to manage
   Observer/Observable relationship. The Monitor class runs in a separate
   thread that interrogates the hardware player and passes on its status
   every second.
   
   The monitor is started by calling the monitor's start() method--in
   this case the call to start() is made in the main() method in Listing
   1. The Monitor's start() method, lines 57 to 65 of Listing 6, creates
   a new thread and starts it running:

if (updateThread == null) {
System.out.println("Starting thread");
updateThread = new Thread(this);
updateThread.start();
}

   The Thread constructor expects to be passed an object that implements
   the Runnable interface, in this case the Monitor is its own Runnable,
   so it passes itself (``this''). To implement the Runnable interface,
   Monitor has to define a run() method. The run() method provides the
   code that will be executed in a new thread. When the
   updateThread.start() method is called the new execution thread will be
   created. The new thread will then call the the monitor's, run()
   method. The run() method loops forever collecting status from the
   cdPlayer, passing it on, and then sleeping one second. The update is
   carried out in a synchronized statement:

synchronized (cdPlayer) {
updateCdInfo();
setChanged();  // Force notifyObservers() to do its thing.
notifyObservers();
}

   The synchronized statement will obtain a lock on the cdPlayer before
   it updates its info and notifies each observer. This ensures that all
   Observers get the same consistent picture. The monitor uses the
   setChanged() method, inherited from Observable, to indicate that the
   Observers need to be informed. It then calls the notifyObservers()
   method, also inherited from Observers, which passes the update event
   on to all Observers who have previous registered with the monitor.
   
   The bulk of the Monitor class on lines 72 to 127 implements the
   updateCDInfo() method that collects info from the Drive/SmartDrive
   object. It caches the CD info to save having to bother the Linux
   kernel with repeated requests for constant information such as the
   length of the tracks on the current CD. The Drive interface was
   extensively covered in my first article, so won't go into the the
   details of the calls to the cdPlayer again here.
   
   Although the monitor provides the main means for conveying status
   information, the SmartDrives's update() method, lines 118 to 148 of
   Listing 5, has to switch into more precise mode to handle the
   transition from one track to the next. The normal one second update
   from the monitor is insufficient to control precise switching between
   tracks so the update() method does it's own frequent polling when ever
   the end of track is near:

if (monitor.currentAddress >= tend - 210) { // Near end of
track?
// Poll frequently so we don't miss the event.
while (currentAddress()
&& monitor.status == Drive.STATUS_PLAY
&& currentAddress() != 0) {
try { Thread.sleep(100); } // Sleep 100 msec's.
catch (InterruptedException e) { }
}

   This ensures that the listener doesn't hear small sound bites of the
   next track.
     _________________________________________________________________
   
  The Program Window
     _________________________________________________________________
   
                                  [INLINE]
                                      
                          Figure 2. Program Window
                                      
   Now we can address the final GUI component--the Program class that
   creates the Program window. The Program window can be seen in Figure
   2. The source code for the program class can be seen in Listing 7. The
   Program class lays out its sub-panels by using the same Form object
   described earlier. The Program constructor, lines 40 to 87, assembles
   three sub-panels:

+ programListing - a text field;
+ trackPanel - a grid of track buttons;
+ and buttonPanel - a row of control buttons.

   The program class isn't really any more complex than the rest of the
   GUI except that it features quite extensive use of Inner Classes and
   Anonymous Classes newly introduced in Java 1.1. Most of the following
   description will concentrate on these two new language features.
   
   Lines 53 to 70 setup the buttonPanel and the actions to take when each
   control button is pressed. The Program() constructor uses the
   Program's own addButton() method to add the control buttons to the
   buttonPanel. AddButton() expects to passed the panel; the button; and
   an object to handle the associated button press action:

void addButton(Panel panel, Button button, DoAction action)
{
panel.add(button);
button.addActionListener(action);
}

   The action parameter, is declared to be from the DoAction class.
   DoAction is declared at the top of the Program class as an Inner
   class--a class contained within the Program class:

class Program extends Form implements Observer {
private abstract class DoAction implements ActionListener {
public void actionPerformed(ActionEvent event) {
this.invoke();
}
abstract void invoke();
}

   The DoAction class is abstract because it has no implementation for
   the invoke() method. The implementation of invoke() is provided
   individually for each button by new sub-classes of DoAction. These new
   sub-classes are created inside the Program() constructor on lines 54
   to 78--each addButton() call creates a new DoAction sub-class:

addButton(buttonPanel,
 editButton,
 new DoAction() { void invoke() { setEditMode(); } });

   In each of these calls to addButton, the last paramter is an Anonymous
   sub-class of DoAction. Like Inner Classes, Anonymous Classes were
   added to Java to give programmers the means for implementing objects
   like ActionListeners without the programmer having to creating
   zillions of free standing mini classes. The new verb, normally used to
   create a new object, is used here to create a new class:

new DoAction() { void invoke() { setEditMode(); } }

   This code creates a new anonymous, i.e., unnamed, sub-class of
   DoAction. The body of the class, in the curly-braces, provides an
   implementation of the invoke() method specific to the editButton. In
   the same manner 6 other anonymous classes are created to handle each
   control button.
   
   Another anonymous class is used to handle the close-request for the
   Program window on lines 71 to 79. Rather than fully declare a single
   class to handle the request, I've used an anonymous sub-class of the
   AWT WindowAdapter class:

new WindowAdapter() {
public void windowClosing(WindowEvent e) {
dismiss(); // call dismiss(0) for the outer class.
}
}

   Again ``new'' is creating a new class. In this case a sub-class of
   WindoAdapter is created with an override for the windowClosing()
   method.
   
   Because these anonymous classes are inner classes of Program, they
   have access to its data and methods. For example, windowClosing() in
   the previous example calls dismiss()--dismiss() is a method of the
   Program class.
   
   The suggested use for Anonymous classes is for small fragments of code
   only. Larger code fragments are more tidily expressed as named inner
   classes.
   
   The updateTrackPanel() method, on lines 171 to 194, contains a tricky
   use of inner classes. Here inner classes are used to carry extra
   information around. When the Program window is created the
   updateTrackPanel() method is called to set up the track-number
   buttons. The method is also called whenever the number of buttons has
   to be altered due to a change in CD.
   
   When the user presses a track-number button, the button event handler
   has to know which button was pressed. updateTrackPanel() achieves this
   by sub-classing the DoAction class:

for (int i = prev_n; i
class TrackAction extends DoAction {
int track;
public TrackAction(int i) { track = i; }
void invoke() { pickTrack(track); }
}
addButton(trackPanel,
 new Button(Integer.toString(i + 1)),
 new TrackAction(i + 1));
}

   Each TrackAction objects is initialised with the track number it is
   associated with.
   
   The rest of the code in the Program class deals with the mechanics of
   programmed mode play. This includes switching the mode of the track
   panel between add (a track), del (a track), and play (immediately play
   a track). The new java feature introduced by this code is the use of
   the JDK Random class to select tracks at random on lines 152 to 169.
     _________________________________________________________________
   
  Summary
     _________________________________________________________________
   
   This concludes my description of how the CD player works. I started
   this whole exercise to try out as much Java as possible, both in terms
   of the compilers and tools, and in terms of the language and JDK
   libraries. I've found that the langauge, libraries, and compilers are
   stable enough to for me to write non trivial programs, the fully coded
   Jcd clocks in at 3600 lines of Java and 450 lines of C. The compilers
   work but are slow. The JDK libraries are quite functional and offer
   far more standard facilities than originally provided with C or C++. C
   integration is easily accomplished. Programming in a garbage collected
   environment is a real boost to productivity. Xemacs provided me with a
   really good Java editing environment.
     _________________________________________________________________
   
  Resources
     _________________________________________________________________
   
   See previous article in Linux Gazette issue 28 for detailed
   references.
   
   Tar file containing all listings in this article
   
   My home page containing more infomation on Jcd.
   
   Jcd is available on Sunsite.
   
   The Linux Java page--a good starting point.
     _________________________________________________________________
   
                     Copyright  1998, Michael Hamilton
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                                EMACSulation
                                      
                              by Eric Marsden
                                      
     This column is devoted to making the best use of Emacs, text editor
     extraordinaire. Each issue I plan to present an Emacs extension
     which can improve your productivity, make the sun shine more
     brightly and the grass greener.
     _________________________________________________________________
   
                               Emacs as a server
                                       
   Many people meet Emacs as the default program launched by Elm to edit
   an email message. Starting up Emacs in this way is a bit of a pain,
   because of the delay and memory use, but also because the fresh Emacs
   doesn't share buffers and a kill ring (storage for cut/copied text)
   with other invocations. Rather than starting up a new Emacs for each
   letter, you can set the environment variable EDITOR to emacsclient.
   
   The Emacs server mechanism allows one Emacs process to service editing
   requests from other applications. To enable it you need to add a line
   like (server-start) in ~/.emacs. When you say emacsclient filename,
   the program searches for an Emacs process (launching one if necessary)
   and sends it a message asking it to edit filename. The caller process
   (the shell for example) is blocked while the file is being edited.
   When you're finished type C-x # and the client will be unblocked.
   
Gnuserv

   Gnuserv is a more sophisticated remote invocation mechanism for Emacs,
   written by Andy Norman (also the author of ange-ftp). It allows
   arbitrary Emacs Lisp commands to be sent to an Emacs process running
   either on the local machine or on another machine on the network.
    1. If you're using XEmacs everything is already set up; you will only
       need to add a (gnuserv-start) to your ~/.emacs.
    2. Obtain the gnuserv-2.1alpha RPM from Red Hat contrib, or the .deb
       for Debian Hamm and skip to 6 ;
    3. Download the source ;
    4. Edit config.h (I suggest using #define DONT_USE_LITOUT) and
       gnuserv.h, where you choose the communication method (the default
       is Internet domain sockets, which is necessary if you want to be
       able to do the remote stuff) ;
    5. Put the file gnuserv.el somewhere in Emacs' load path. Let's
       assume you have an ~/elisp/ directory where you put your favorite
       Emacs Lisp extensions; an alternative is to copy gnuserv.el to a
       site-wide Emacs Lisp directory such as /usr/lib/emacs/site-lisp
       (type C-h v load-path in Emacs to see a list of possiblities) ;
    6. Add something like this to your ~/.emacs :

    (setq load-path (cons (expand-file-name "~/elisp") load-path))
    (autoload 'gnuserv-start "gnuserv" "Better Emacs server support")
    (setq gnuserv-frame (current-frame))
    (gnuserv-start)
       The second line tells Emacs that the function gnuserv-start is
       defined in a file called gnuserv.el, which Emacs will load on
       demand. The third line inhibits the default behaviour of opeing a
       new frame for each new file edited (leave this out if you prefer).
       The last line fires up the server.
       
   To check that everything is working, type
    ~$ gnuclient <filename>

   which asks Emacs to open <filename>, just like emacsclient. If this
   doesn't work (with a message like ``Refused connection'' or ``Broken
   pipe''), skip down to the Security section. You can also send off an
   arbitrary bit of Emacs Lisp :

    ~$ gnudoit '(message "Hi there, %s!" (user-full-name))'

Applications

   Now you can do all sorts of silly things. You could get two Emacsen on
   networked machines to play ping pong, echoing messages back and forth.
   You could use Emacs as a CGI script server, profiting from its
   powerful library without incurring the overhead of launching an
   interpreter for each script (a little like the FastCGI mechanism). For
   example, let's hack together an external interface to Emacs' builtin
   psychologist :

     (defun eliza-start ()
       "Fire up the doctor."
       (interactive)
       (doctor)
       ;; We only have to type return once under this interface.
       (re-search-backward " twice" nil t)
       (replace-match "")
       (goto-char (point-max))
       (buffer-substring (point-min) (point-max)))

     (defun eliza-continue (str)
       "Send a string to the doctor and return her response."
       (interactive)
       (switch-to-buffer "*doctor*")
       (insert "\n" str "\n")
       (doctor-read-print)
       (save-excursion
         (re-search-backward "\n\n\\(\\(.+\n?\\)+\\)\n\n")
         (match-string 1)))

     (defun eliza-cleanup ()
       "Pay the bill and leave."
       (interactive)
       (let ((buf (get-buffer "*doctor*")))
          (if buf (kill-buffer buf))))

   This can be used from the command line (for CGI use you'd have to
   think about the trickier question of concurrent accesses) with a
   script such as

     #! /bin/sh

     gnudoit '(eliza-start)'
     while read line
     do
         gnudoit "(eliza-continue \"$line\")"
     done
     gnudoit '(eliza-cleanup)'

   You might even find constructive uses for the gnuserv technology, like
   starting Gnus (an Emacs news/email client) and ange-ftp transfers from
   a ``network Emacs'', so that your primary Emacs isn't affected by
   networking delays. You could also communicate with Emacs from a
   crontab, telling it to fetch some web pages with Emacs/w3, or send
   someone an email. You could use Netscape's third party email/news API
   to invoke Emacs instead of the builtin mail and news clients. It might
   also be useful for sending commands to Emacs from a window manager
   menu.
   
Security considerations

   More and more Linux distributions use good X security as set up out of
   the box. You will notice for example that when you su to root on a
   modern system, you will no longer be able to launch X clients, because
   the X server is protected by an xauth cookie.
   
   While allowing access to your X display is bad enough (someone could
   capture all your keystrokes, for example), giving remote access to
   your Emacs process is much more worrying, since Emacs can execute
   arbitrary commands under your id, delete files, send insulting email
   to the President of the United States, etc.
   
   Since release 2.1, gnuserv is able to use MIT-MAGIC-COOKIE-1
   authentication for remote requests. This protocol uses the contents of
   your ~/.Xauthority file, as described in the xauth(1) man page.
   Gnuserv requires a cookie for display number 999, which you can create
   as follows (blade is the name of the machine) :

      ~$ xauth add blade:999 . `cat /etc/passwd | md5sum`
      ~$ xauth list
      blade/unix:0  MIT-MAGIC-COOKIE-1  bc1d627babdbabe9d1f288d2b57c348f
      blade:999  MIT-MAGIC-COOKIE-1  d89570b20925d401c05a79be67159cae

   (`cat /etc/passwd | md5sum` is just a convenient way of generating a
   cookie; on most Linux systems you will be able to use the mcookie
   command, or you can bake a cookie by hand). Now you should be able to
   use gnuclient/gnudoit on the local machine. The next step is to
   transfer the cookie to each remote machine from which you plan to
   access Emacs, with a command such as :

      ~$ xauth extract - blade:999 | rsh remotehost.edu xauth merge -

   If you don't run X you will have to fall back to a host-based access
   control system : the environment variable GNU_SECURE is assumed to
   point to a file which contains a list of machines which are authorized
   to open connections to your Emacs process. Finally, if your machine
   isn't networked, you've probably already skipped to the next section.
   
How does it work?

   Your command takes a fairly convoluted route to reach Emacs. There are
   four parties involved in a transaction : the ``client'', or program
   which wants a service from Emacs (Elm for example), the gnuclient
   program (which runs on the requesting machine), the gnuserv process
   (which runs on the machine running Emacs), and of course the Emacs
   process itself. They communicate as indicated by the following
   diagram :
   
   Communication diagram (3 kB)
   
   The fragile aspect of the system is that if the gnuserv program dies
   for some reason, everything grinds to a halt. An alternative
   communication method which would involve fewer working parts could be
   inspired from the Netscape remote invocation protocol. The gnuclient
   capabilities would be added directly to Emacs, and a gnudoit request
   would look something like

    emacs -remote -lisp '(message "Hi")'

   The new Emacs process would search for an existing Emacs process to
   which it could dispatch the request, or service it directly. The
   disadvantage is that each request would be slower, since an Emacs
   needs to be forked each time. The image is most often in the disk
   cache, so this wouldn't be catastrophically slow (it works OK with
   Mozilla, which is far bigger than Emacs).
   
Next time ...

   I've received a fair bit of email asking how to customize various
   aspects of Emacs, so I'll try to scratch the surface of this vast
   topic next month, and discuss the Customize package. Don't hesitate to
   contact me at <emarsden@mail.dotcom.fr> with comments, corrections or
   suggestions (what's your favorite couldn't-do-without Emacs extension
   package?). C-u 1000 M-x hail-emacs !
   
   PS : Emacs isn't in any way limited to Linux, since implementations
   exist for many other operating systems (and some systems which only
   halfway operate). However, as one of the leading bits of free
   software, one of the most powerful, complex and customizable, I feel
   it has its place in the Linux Gazette.
     _________________________________________________________________
   
                       Copyright  1998, Eric Marsden
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
            The Importance of Adopting an In-House Linux Expert
                                      
                               By Carlo Prelz
     _________________________________________________________________
   
   Changes, even huge changes, are difficult to evaluate when you happen
   to live close to whatever is undergoing the change, be it a child,
   global politics, or the world of people who make a living with their
   knowledge of information technology (IT) matters.
   
   In our world, as the most common computer-dependent tasks get
   standardized and as more and more raw computing power can be tapped by
   more people, the figure of the white-clad ``computer priest'' is about
   to vanish. But what is the world getting in exchange?
   
   How is the young manager of a new company going to build its IT
   infrastructure? No, he most likely won't phone IBM. Instead, he will
   order a bunch of PCs, equipped with a various assortment of Microsoft
   software. Other Microsoft software will follow, because that's what
   everybody does.
   
   Through a brief, fractal period, we have moved from one monopoly to
   another, with the added disadvantage that people who blindly accept
   the new easy solution end up with less-than-solid material. This
   material is much harder to adapt to local needs. In the past,
   companies who could afford a high level of informatization hire with a
   handful of COBOL or RPGII programmers who could customize the software
   that needed to be adapted.
   
   Today, a manager will most probably be equipped with a NT server, a
   Microsoft Office suite on Windows 95 for each desk, an Ethernet
   network, and an assistance contract with some specialized firm (who
   has to deal with dozens of other companies). He may organize things so
   that his people have some limited sort of Internet access. All
   standard, on a path that is being walked on by a huge mass of people
   all around the globe.
   
   As the path gets dug deeper and deeper, it gets harder to choose a
   different one. This has to do with gravity: the deeper the path and
   the steeper its sides, the harder the person, company or organization
   has to want to choose a personal way to its own IT goals.
   
   But why would a reasonable IT manager want to get out of the
   mainstream? The keyword is customization.
   
   Yes, you can program in Windows. But when it gets to having an
   ``intimate'' relationship with what actually happens, Windows leaves
   you in the cold. You may find books, but unless you have uncommonly
   strong links with the Microsoft engineering circles, you have no way
   to be confident in the fact that whatever OS feature you are using
   won't disappear without a trace in the next release. Which you will
   have to use because everybody will be using it at a certain time. You
   end up being dependent on the next brilliant idea they come up with at
   Redmond, WA.
   
   This strategy is evident. Human beings' laziness is again tapped, at
   the benefit of a company that found itself at the right space-time
   coordinates, and has been as un-principled as needed.
   
   But if our young manager were to dedicate a moment of thought to how
   to solve his IT problems, what are his choices?
     * If he has enough resources, he can go the mainframe way. The road
       is still open and fast becoming an elitist choice.
     * If his connections with IBM are vital, or for a series of
       (constantly diminishing) other reasons, he may go the OS/2 way.
     * He may be romantic and like Macintoshes. There are concrete
       rewards in these choices, although these give the impression of
       diminishing, too.
     * He may instead choose the proprietary UNIX way--yes, the
       overpriced one.
     * If he has a curious attitude, chances are that he has already met
       Linux, and that he has seen Linux mentioned at an increasing rate
       during the past months. Thanks to the Net, there is no scarcity of
       information open to whomever decides to look around a bit.
     * He may also decide to either write or pay somebody to write an
       operating system from scratch. This seems somewhat improbable.
       
   Let me know if I missed some important options. But of all the above,
   the one that promises to bear more fruit is the Linux way. So, how to
   give it a try? The best solution for a manager who would like his
   computers do what is needed without learning the way himself, is to
   engage the services of one or more Linux aficionados.
     _________________________________________________________________
   
  The Linux Aficionado
     _________________________________________________________________
   
   Linux has been growing like a big, healthy forest plant. Each branch
   has been contributed by someone like us, who decided to spend a bit of
   their free time to make the tree look and live better. Not ``for
   free'': we humans always do things for a reward; it happens that money
   is not the only (nor the best) reward. The impulse behind the Free
   Software movement has been and still is to demonstrate to ourselves
   and to the world that we worked well, that we brilliantly solved a
   problem. That we created a handy tool, that was not there before. That
   is, that the world is now a little bit nicer now than before we
   started developing our ideas.
   
   Of course, programmers need to survive, too. Here is what the Richard
   Stallman has to say about the topic (excerpt from the GNU Manifesto):
   
     ``Won't programmers starve?''
     
     I could answer that nobody is forced to be a programmer. Most of us
     cannot manage to get any money for standing on the street and
     making faces. But we are not, as a result, condemned to spend our
     lives standing on the street making faces, and starving. We do
     something else.
     
     But that is the wrong answer because it accepts the questioner's
     implicit assumption: that without ownership of software,
     programmers cannot possibly be paid a cent. Supposedly it is all or
     nothing.
     
     The real reason programmers will not starve is that it will still
     be possible for them to get paid for programming; just not paid as
     much as now.
     
     Restricting copying is not the only basis for business in software.
     It is the most common basis because it brings in the most money. If
     it were prohibited, or rejected by the customer, software business
     would move to other bases of organization which are now used less
     often. There are always numerous ways to organize any kind of
     business.
     
     Probably programming will not be as lucrative on the new basis as
     it is now. But that is not an argument against the change. It is
     not considered an injustice that sales clerks make the salaries
     that they now do. If programmers made the same, that would not be
     an injustice either. (In practice they would still make
     considerably more than that.)
     
   The above was written back in 1985, when programmers were still
   earning big money; 12 years later, our market and contracting power
   has diminished a lot. Gone are the days when a programmer could be the
   best paid man in the company thanks to writing huge bits of database
   access/data entry pieces of software that differed very little from
   their brothers.
   
   When the need arises for an application that is somehow different,
   there is no other way than to call an actual programmer. Here are a
   few characteristics that make a Linux aficionado an ideal choice for
   such a special need:
     * Passion. Something better than money as the reason for what we do.
     * Love for quality. Learning from previous experience, and being
       able to judge and better our work.
     * Ability to solve problems. If a problem exists, we like see it
       solved in the best possible way, and we generally find a way.
     * Loyalty. If we are given recognition, an interesting place to work
       in, interesting things to do and a reasonable wage, we may oppose
       more than normal resistance to the lure of head hunters.
       
   I may like to add a couple of counter-indications:
     * Lack of particular enthusiasm for wearing ties or adopting
       uniforms (or respecting poorly justified liberticide rules).
     * The wish to understand what one is doing renders less than
       desirable a sort of job where you must focus on a tiny fraction of
       the whole thing, knowing nothing about the complete picture.
     _________________________________________________________________
   
  No Need for Another Windows95
     _________________________________________________________________
   
   There are recurring, well-financed efforts to create a new
   good-for-everybody operating system on the robust structure of Linux.
   These efforts are justified by the hope of snatching even a small
   percentage of the huge market held by Microsoft. A very small
   percentage of a very large sum may promise reasonable earnings to
   those who follow this path.
   
   Regardless of how things look like now, the omnipresent PC that we see
   today has a limited time to live.
   
   A very big slice of the PCs that are currently in use in the world are
   used for standard operations: keeping one's correspondence, making
   spreadsheet calculations, maintaining one's agenda, playing games and
   looking around the Internet. How many PCs do you know are being used
   with software that has been written especially for them? The logical
   direction, one that much effort has been spent to hamper, is that of
   including everything that a secretary, a non-IT-oriented office worker
   or a common home user will ever need in an idiot-proof box.
   
   This tendency has at last emerged in the shape of network computers.
   No matter which way is selected, the result of adopting an NC is that,
   from the prospective of the user, there will simply be a couple of
   plugs to insert into the respective sockets, and the user will be
   ready to work or play. No need to reinstall Windows95 for the nth time
   because the maintainer can't divine a better way to recover from the
   cryptic error messages.
   
   Along this way, comes the demise of shrink-wrap software. If the
   server is the only place where a separate operating system needs to be
   installed, it will be much harder for Microsoft to maintain their
   stronghold on the computer market. NT has very little advantage
   compared to the many UNIX options in the field. In particular, it is
   not significantly easier to manage than UNIX by a knowledgeable
   person. And if or when the networked world becomes so easy to manage
   that a bunch of software wizards can do the job, the next step will be
   NSes (Network Servers, I think I'll patent the name...). Again,
   something that spells bad to a software-only company that is
   programmed to EARN.
   
   Isn't it futile to try to be the new Microsoft? As if it really
   mattered much to have so much money that you will not have the
   material possibility to spend it all in your lifetime.
     _________________________________________________________________
   
  Meet the Ideal Entrepreneur
     _________________________________________________________________
   
   So, what is there that is not futile? Doing something nice, that makes
   the world a bit better. I said that before.
   
   A human being has an idea. Some say they float around, and visit you
   when you become receptive enough. She finds all the resources that are
   needed to turn this idea into a practical product. After some time,
   other people can exchange some of their own wealth to take advantage
   of the idea of our entrepreneur.
   
   Or the idea can be imported within a sufficiently fertile existing
   corporation, one that will recognize the value of the idea and give
   our human being enough space and resources to reach her goal.
   
   Or the idea deals with bettering an established way of doing some
   task.
   
   What kind of enterprise can you think of, that won't benefit from the
   use of IT? Most of the times, she will have to look for computer
   assistance. It is to all the entrepreneurs who are facing the problem
   of which way to informatize their pet project that I would like to
   speak.
   
   Linux may well be the best choice for you. But for Linux to adapt well
   to your world, you will want to adopt one or more Linux aficionados.
   You will want to secure the continuing services of a person who deeply
   knows and appreciates the tools he works with. Who can craft your
   personal solution. Who can maintain the operating system that your
   solution works on abreast of the latest technical progress.
   
   Linux cannot be eternal. Nothing is. But it has reached a solid,
   mature stage NOW. Especially, it is the ideal tool for tapping into
   the networked world. Now is the time not to be lazy and to profit from
   this situation. And keeping a Linux aficionado happy and well-fed now
   might also imply finding yourself in a more elevated position in the
   post-Microsoft world, tomorrow.
     _________________________________________________________________
   
                       Copyright  1998, Carlo Prelz
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                   Mastering Kernel Modules with Caldera
                                      
                              By David Nelson
     _________________________________________________________________
   
   You shouldn't have to read this article. The concept of Linux kernel
   modules is fairly simple. Unfortunately, information needed to
   compile, install and use modules is scattered over several HOWTOs,
   READMEs, and man pages. Plus, the files which need to be modified are
   in several obscure directories.
   
   I finally wrote this cookbook approach to get myself, and you,
   started. Once you are up and running with modules, you can dig into
   the details later. I tested this material on an X86 processor running
   Caldera Open Linux 1.1, which is close to Red Hat 4.2. You mileage
   with other processors and distributions may vary.
   
   Why use modules? Modules let you compile a small, fast kernel, then
   install and remove device drivers on demand. Without modules the Linux
   kernel could bloat to resemble a certain commercial OS.
   
   First, I recommend that you compile a base kernel that includes all
   essential capabilities for your system without modules. I know this
   sounds like we are going backwards, but you don't want to lose the
   ability to boot up because you messed up your modules. The README in
   usr/src/linux is your guide, but basically you execute the command:

make mrproper; make xconfig

   (or menuconfig or config) to include all needed capabilities, then
   run:

make dep; make clean; make zImage

   Save your kernel configuration to a file named kernelconf.base, in
   case you need to recompile. The xconfig menu prompts you to save and
   load configuration files. If you use menuconfig or config, the current
   configuration is in the file /usr/src/linux/.config; copy that file to
   kernelconf.base. If you configured too big a kernel, final compilation
   will fail. If this happens, execute make bzImage instead of zImage.
   Your compiled kernel will be in the directory
   /usr/src/linux/arch/i386/boot.
   
   You might have made a mistake in compiling your base kernel, so don't
   throw away your old one. If you are running LILO, rename your new
   kernel to zImage.base and copy it to the location of your current
   kernel, usually / or /boot. Add a section to /etc/lilo.conf that lets
   you select either your default or base kernel on boot up. My lilo.conf
   is shown here minus some comment lines:

# general section
boot = /dev/hda3
install = /boot/boot.b
message = /boot/message
prompt
timeout = 50

# default entry
image = /bzImage
        label = linux
        root = /dev/hda3
        read-only

# base kernel
image = /zImage.base
        label = base
        root = /dev/hda3
        read-only

   The important addition to lilo.conf is the last section (#base kernel)
   which tells LILO about your new kernel. Also, be sure lilo.conf has
   prompt and timeout lines. Now execute lilo and then reboot. LILO will
   pause giving the prompt boot:. If you hit TAB, you will be given the
   choices linux and base. Enter base, and your new kernel will boot. You
   may get complaining messages about bad module dependencies, but if
   your base kernel is complete that shouldn't bother you. If something
   goes wrong, reboot and enter linux (or just wait the timeout interval)
   and your old kernel will boot. Make sure you have a working base
   kernel before proceeding. With this approach you never burn your
   bridges (or kernel) behind you.
   
   If you don't use LILO, make a boot floppy for your base kernel. To do
   this, insert a floppy and execute make zdisk, instead of zImage.
   
   You are now ready to compile a kernel with modules tailored to your
   system. Execute the same commands as above, but when you execute
   xconfig or menuconfig pick some features to compile as modules. I
   suggest you experiment first by picking nice-to-have, but
   not-necessary, modules to add to zImage.base. Good choices might be
   printer support or floppy support (unless you are booting from the
   floppy). Save your configuration as kernelconf.mod in case you need to
   go back. Also, write down which modules you are compiling. To know
   exactly which modules are compiled, I suggest you move or delete your
   old modules (if any). The Caldera release includes a lot of modules.
   They are in /lib/modules/2.0.29. I moved my old ones into
   subdirectories rather than deleting them in case I needed to back up.
   If you are working with a different release of the kernel, instead of
   subdirectory 2.0.29 you will have a subdirectory corresponding to your
   release number.
   
   After executing make zImage, run:
make modules; make modules_install

   As before, move (using cd) to the directory containing zImage, rename
   it zImage.mod and move it to the directory where LILO will look for
   it. Put a new section at the bottom of lilo.conf to let you boot this
   kernel with the label modules. If you don't use LILO, make another
   zDisk.
   
   Now, execute depmod -aq. This creates /lib/modules/2.0.29/modules.dep,
   needed by module utilities. Next, execute the following:

modprobe -c | grep -v '^path' > /etc/conf.modules

   This command sets up another file needed by the module utilities.
   
   Now reboot, choosing label modules at the boot prompt. Next, move to
   the /etc/modules/2.0.29 directory. It should contain a file with a
   very long name like the following:

#1 Tue Feb 11 20:36:48 MET 1997.default

   This file is read at boot time by /etc/rc.d/rc.modules. It contains a
   list of the default modules loaded when the kernel boots. You need to
   change both the name and the contents. Fixing the name is the hard
   part. In directory /etc/modules/2.0.29 execute the commands:

FILE=i`uname -v`.default
cp "#1 Tue"* "$FILE"

   This magic creates a file with the name that rc.modules will look for
   on bootup. The name is based on the time when the kernel was compiled.
   If you recompile the kernel, you must repeat the magic.
   
   Edit this file to contain just the modules you want loaded at bootup.
   For example, it might contain the lines

floppy
lp

   which would load the floppy and printer modules, assuming you compiled
   them as modules. To get your editor to accept this file, you may need
   to put quotes around the name.
   
   To load a module manually, execute insmod 'modname'. To remove it
   execute rmmod 'modname'. To tell which modules are currently loaded,
   execute lsmod.
   
   The best toy is kerneld; it automatically loads and unloads modules as
   needed. Assume you have compiled the floppy driver as a module. Check
   whether it is loaded by executing lsmod. If it is, remove it by
   executing rmmod floppy. Then execute kerneld. Now execute
   mount /mnt/floppy (or whatever mounts your floppy). Magically, kerneld
   installs the floppy module when needed. It will also uninstall modules
   which haven't been used for a while, keeping your kernel lean and
   mean.
   
   You now know enough to experiment with modules without crashing your
   kernel on bootup. Read the Module mini-HOWTO, the kerneld mini-HOWTO,
   and the man pages for the utilities to become a real expert. Happy
   moduling!
     _________________________________________________________________
   
  Resources
     _________________________________________________________________
   
   Module mini-HOWTO
   
   kerneld mini-HOWTO
     _________________________________________________________________
   
                       Copyright  1998, David Nelson
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
   Replacing Windows NT Server with Linux
   Copyright (c) 1997 Quinn P. Coldiron
   qcoldiro@unlinfo.unl.edu
   Table of Contents
   
   Introduction
   
   Section 1--Outlining Our Situation
   
   Section 2-- Why we chose RedHat Linux
     * Linux Features
     * Reliability
     * Cross platform
     * Compatibility
     * Speed
     * Inexpensive
     * Low hardware requirements
     * Ease of administration
     * Simple upgrade path
     * Remote control and administration
       
   Section 3--Under the Hood
     * Setting up the server
     *        Linux installation
     *        Samba installation/setup
     *        Netatalk installation/setup
     * Installing The Cats Pajamas (Getting a DOS network application to
       run on Linux)
     *        Installing Cats on the Server
     *        Configuring your Windows clients
     *        Configuring the DOS emulator to run Cats
     * Installing a RAID
     * Daily administration
     *        System backups
     *        Scheduling events
     * Replacing your Desktop OS with Linux
       
   Appendix A--RedHat 5.0 Installation Guide
   
   Appendix B--Samba
     * Just What is SMB?
     * Samba FAQ
     * Samba HOW-TO
       
   Appendix C--DOSEMU Manual
   
   _________________________________________________________________
   
   Introduction
   
   Network Operating Systems (NOS) have many features and capabilities
   that allow the Information Systems departments of most organizations
   to better server your organization and help streamline work flow. Each
   NOS has different features and a excels in different areas.
   Traditionally, Novell Netware has been viewed as the best file/printer
   server, Unix was viewed as the premiere application and database
   server and recently, Windows NT has come in as a good choice for the
   smaller networks as a file/printer server or application server. The
   market has become very aggressive with each of these platforms
   branching out into each others market area. Microsoft has expanded NT
   into the midrange server market once dominated by Novell and is trying
   to get into the high end market which was once filled by Unix venders
   such as Sun, Hewlett Packard and Silicone Graphics.
   
   I inherited an aging Novell Netware 3.11 server when I began my career
   at the University of Nebraska Press that was on an under powered
   Pentium 90 and had older disk drives that were failing. I also wanted
   to expand into other areas, so I knew this was going to be my first
   project. When I began looking at my options to replace our aging
   Novell Netware server, I of course turned first to the just released
   Windows NT Server 4.0. The marketing materials, magazines and
   television advertisements all told me that this was the one thing that
   would solve all my problems. The operating system promised to be
   easier to setup and maintain than the Netware product it was replacing
   and it could easily handle the 55 users on my network. Fourteen months
   later, we are running Linux as our server.
   
   Linux is a completely free reimplementation of the POSIX
   specification, with SYSV and BSD extensions (which means it looks like
   Unix, but does not come from the same source code base), which is
   available in both source code and binary form. Its copyright is owned
   by Linus Torvalds <torvalds@transmeta.com> and other contributors, and
   is freely redistributable under the terms of the GNU General Public
   License (GPL). A copy of the GPL is included with the Linux source;
   you can also get a copy from ftp://prep.ai.mit.edu/pub/gnu/COPYING.
   
   Linux is not public domain, nor is it `shareware'. It is `free'
   software, commonly called freeware, and you may give away or sell
   copies, but you must include the source code or make it available in
   the same way as any binaries you give or sell. If you distribute any
   modifications, you are legally bound to distribute the source for
   those modifications. See the GNU General Public License for details.
   
   Linux is still free as of version 2.0, and will continue to be free.
   Because of the nature of the GPL to which Linux is subject, it would
   be illegal for it to be made not free. Note carefully: the `free' part
   involves access to the source code rather than money; it is perfectly
   legal to charge money for distributing Linux, so long as you also
   distribute the source code. This is a generalization; if you want the
   fine points, read the GPL.
   
   Linux runs on 386/486/Pentium machines with ISA, EISA, PCI and VLB
   busses. MCA (IBM's proprietary bus) is not well-supported in 2.0.x and
   earlier versions, but support has been added to the current
   development tree, 2.1.x. If you are interested, see
   http://glycerine.itsmm.uni.edu/mca
   
   There is a port to multiple Motorola 680x0 platforms (currently
   running on some Amigas, Ataris, and VME machines), which now works
   quite well. It requires a 68020 with an MMU, a 68030, 68040, or a
   68060, and also requires an FPU. Networking and X now work. See
   news:comp.os.linux.m68k
   
   Linux runs well on DEC's Alpha CPU, currently supporting the "Jensen",
   "NoName", "Cabriolet", "Universal Desktop Box" (better known as the
   Multia), and many other platforms. For more information, see
   http://www.azstarnet.com/~axplinux/FAQ.html
   
   Linux runs well on Sun SPARCs; most sun4c and sun4m machines now run
   Linux, with support for sun4 and sun4u in active development. Red Hat
   Linux is (as of this writing) the only Linux distribution available
   for SPARCs; see http://www.redhat.com/support/docs/rhl-sparc/
   
   Linux is being actively ported to the PowerPC architecture, including
   PowerMac (Nubus and PCI), Motorola, IBM, and Be machines. See
   http://www.cs.nmt.edu/~linuxppc/ and http://www.linuxppc.org/
   
   Ports to other machines, including MIPS and ARM, are under way and
   showing various amounts of progress. Don't hold your breath, but if
   you are interested and able to contribute, you may well find other
   developers who wish to work with you.
   
   Linux is no longer considered to be in beta testing, as version 1.0
   was released on March 14, 1994. There are still bugs in the system,
   and new bugs will creep up and be fixed as time goes on. Because Linux
   follows the ``open development model'', all new versions will be
   released to the public, whether or not they are considered
   ``production quality''. However, in order to help people tell whether
   they are getting a stable version or not, the following scheme has
   been implemented: Versions 1.x.y, where x is an even number, are
   stable versions, and only bug fixes will be applied as y is
   incremented. So from version 1.2.2 to 1.2.3, there were only bug
   fixes, and no new features. Versions 1.x.y, where x is an odd number,
   are beta-quality releases for developers only, and may be unstable and
   may crash, and are having new features added to them all the time.
   From time to time, as the current development kernel stabilizes, it
   will be frozen as the new ``stable'' kernel, and development will
   continue on a new development version of the kernel.
   
   The current stable version is 2.0.31 (this will continue to change as
   new device drivers get added and bugs fixed), and development has also
   started on the experimental 2.1.x kernels. If 2.0.x is too new for
   you, you may want to stick with 1.2.13 for the time being. However,
   the latest releases of 2.0 have proved quite stable. Do note that in
   order to upgrade from 1.2 to 2.0, you need to upgrade some utilities
   as well; you may wish to upgrade to the latest version of your Linux
   distribution in order to obtain those utilities. The Linux kernel
   source code also contains a file, Documentation/Changes, which
   explains these changes and more.
   
   Most versions of Linux, beta or not, are quite stable, and you can
   keep using those if they do what you need and you don't want to be on
   the bleeding edge. One site had a computer running version 0.97p1
   (dating from the summer of 1992) for over 136 days without an error or
   crash. (It would have been longer if the backhoe operator hadn't
   mistaken a main power transformer for a dumpster...) Others have
   posted uptimes in excess of a year. One site still had a computer
   running Linux 0.99p15s over 600 days at last report.
   
   One thing to be aware of is that Linux is developed using an open and
   distributed model, instead of a closed and centralized model like much
   other software. This means that the current development version is
   always public (with up to a week or two of delay) so that anybody can
   use it. The result is that whenever a version with new functionality
   is released, it almost always contains bugs, but it also results in a
   very rapid development so that the bugs are found and corrected
   quickly, often in hours, as many people work to fix them.
   
   In contrast, the closed and centralized model means that there is only
   one person or team working on the project, and they only release
   software that they think is working well. Often this leads to long
   intervals between releases, long waiting for bug fixes, and slower
   development. The latest release of such software to the public is
   sometimes of higher quality, but the development speed is generally
   much slower.
   
   As of October 24, 1997, the current stable version of Linux is 2.0.31,
   and the latest development version is 2.1.59.
   
   I will begin this report by covering the areas that we were concerned
   about and giving reasons that were chose options that we went with. I
   will not get very technical in this fist section, but will cover in
   detail how we implemented each part of the system and give examples of
   the configuration files in section two.
        _________________________________________________________________
                                                                         
                                                                Section 1
                                                                         
                                                  Outlining Our Situation
                                                                         
                                                            Our Situation
                                                                         
   When I became the Information Systems Department manager for the
   University of Nebraska Press I inherited a very tired and aging Novell
   Netware 3.1 server that was handling all the network serving duties
   for approximately fifty users. This is not a large network and our
   needs are not out of the ordinary, but this machine was due for
   replacement. Novell was on version 4.x, NT 4.0 had just come out and
   this machine was only a Pentium 90 with data drives that were noisier
   than Nebraska's memorial stadium.
   
   It was time to begin the search for replacements and I had the same
   issues to deal with that my predecessors had, plus some new ones. The
   main issue was compatibility with our order fulfillment and inventory
   system called The Cat's Pajamas. This system was originally developed
   on the Data General line of mini and mainframe computers using its
   interpreted language. The system was ported to PC servers (mainly
   Novell Netware) when a company called Subject Wills ported the
   interpreter to the PC platform. It has a character based user
   interface, stores all its data in flat indexed text files and is
   pretty fast and stable on the Novell platform. Our new requirements
   were for remote access for our warehouse, and if possible, access for
   the five Macs that we have, but spend as little money as possible.
   
   I was not very interested in upgrading our current Netware license,
   since at this time Novell was playing the CEO of the Month game which
   had caused me to lose much of my confidence in the company. The next
   logical choice was Microsoft Windows NT. I called Cats and asked if
   the application would run on NT and they told me that they had a few
   installations and things seemed to be running fine, but I would need a
   different version of the DBC interpreter, which they uploaded for me.
   I proceeded to copy the entire system and database to the NT server
   and logged on from my Windows 95 PC. I had to rewrite the batch file
   that Cats uses to start because they were using Netware network
   commands, but I was able to get them changed and get a session up.
   
   At this point I thought this looked very good, so I ordered the
   production server. The server was a dual CPU Pentium 150 with built in
   Adaptec 2940UW SCSI controller and 256MB of RAM. I thought this would
   be perfect to act as the CATS server, file server and printer server
   for 50 people, especially since Netware was doing this on a Pentium 90
   with 64 MB of RAM. I got the server a few weeks later, installed NT
   4.0 and Cats. After I got Cats installed I had our business department
   and Customer Service department try running some large and CPU
   intensive reports on it and things seemed to run great, so we pushed
   it into service. At this same time I was setting up a RedHat Linux 4.1
   machine on a Pentium 100 with 32 MB of RAM. I had used RedHat Linux in
   my previous position with great luck as a web server and StreamWorks
   audio/video server so I wanted to see if it could fit in here, but I
   didn't know where or how.
   
   Life after moving Cats to NT was a nightmare. The system was crashing
   two to three times a day with no reason that I could find. I was on
   the phone with Microsoft and Cats constantly, but nobody could figure
   it out. Microsoft had me apply Service Packs one through three and a
   few HotFixes, which helped, but it still was crashing at least twice a
   week with the infamous "Blue Screen of Death". After many weeks and
   about $1500.00 in phone support from Microsoft, the technical support
   rep told me that I should find a better software package than The
   Cat's Pajamas. This is was not the solution I was looking for, since
   this is the package that a sizeable percentage of presses our size
   nationwide are running, so I was forced to bring the old Novell server
   back into production until I could figure something out.
   
   By this time I had upgraded the RedHat Linux machine to version 4.2,
   but it still wasn't doing much, so I added two IDE 1.6 GB hard drives,
   installed SAMBA and copied CATS over to this computer to play a
   little. I was able to connect from my Windows 95 computer and run Cats
   without any modifications to the batch file I had created for the NT
   server. I had the Business manager and Customer Service manager try
   the reports again and everything seemed fine, but I still had my
   doubts, so I just kept the system up for myself and the IS department
   to test until a later date.
   
   The Netware server was still holding on and doing its job until I got
   a call one Thursday night at about 9:00 from our Customer Service
   manager. He had been running the reindexing program to prepare for the
   month-end closing that was to start Friday, but the server had
   crashed. I worked on it until about 12:30 am and finally got it
   working, but the whole thing died again Friday morning at about 6:30
   and again at 7:00, so I knew we were in trouble. The only option left
   was to replace the server now and the only thing I had was the Linux
   server, so I restored Cats off our Windows NT tape backup machine to
   the Linux server and changed the login scripts to connect the users to
   this server for the Cats drives. Within one hour, we were back in
   operation.
   
   After completing the morning duties, we normally run a complete Cats
   backup before we continue with closing which usually would take two
   hours to complete on the Netware server. The Linux machine was able to
   do the entire backup in 45 minutes, cutting a little over an hour off
   our closing time. This increase in speed came from a decrease in
   hardware because the Linux server was running only 32 MB in RAM and
   IDE hard drives where the Netware server had 64 MB in RAM and SCSI
   drives. The speed increase has been noticed in daily work also. I get
   almost daily remarks that the system seems to be running faster and
   more reliable.
   
   We have recently upgraded the CPU to a 200Mhz Pentium and have
   upgraded the Memory to 64 MB to handle the newest plans of making this
   server replace our Windows NT file/printer server, which still crashes
   about twice a month for no reason, even after an additional $1,500 in
   tech support with Microsoft. This single computer running RedHat Linux
   will replace both our Novell Netware 3.11 server and our Windows NT
   4.0 server, while decreasing total hardware requirements. With the
   recent advances from the Samba team in supporting the NT domain
   structure and the December 1997 release of RedHat 5.0, I expect to
   have a very efficient and inexpensive server for our Windows 95,
   Windows NT and Macintosh clients.
        _________________________________________________________________
                                                                         
                                                                Section 2
                                                                         
                                                Why We Chose RedHat Linux
                                                                         
                                                           Linux Features
                                                                         
   Linux is a very feature rich operating system. Many of its features
   are not found on its commercial competitor Windows NT due to the fact
   that Unix has been in constant development since it was invented in
   the early 1970's. Even though Linux has only been around since the
   early 90's, it benefits from the rich archives of Unix applications
   and utilities because of its POSIX compliance. Linux is unique in that
   the kernel does not use any code from previous Unix implementations,
   but can still tap into the libraries of BSD and System V
   distributions. I feel the strongest feature of Linux is the Internet
   itself and the many technical users that are responsible for the
   development of the many drivers and ports to other hardware platforms.
   Many Intel platform bug fixes are release for Linux before they are
   release in other ``mainstream'' operating systems mainly due to the
   fact the users are also the developers.
     *  multitasking: several programs running at once.
     *  multi-user: several users on the same machine at once (and no
       two-user licenses!)..
     *  multiplatform: runs on many different CPUs, not just Intel.
     *  multiprocessor: SMP support is available on the Intel and SPARC
       platforms (with work currently in progress on other platforms),
       and Linux is used in several loosely-coupled MP applications,
       including Beowulf systems (see
       http://cesdis.gsfc.nasa.gov/linux-web/beowulf/beowulf.html) and
       the Fujitsu AP1000+ SPARC-based supercomputer.
     *  runs in protected mode on the 386.
     *  has memory protection between processes, so that one program
       can't bring the whole system down.
     *  demand loads executables: Linux only reads from disk those parts
       of a program that are actually used.
     *  shared copy-on-write pages among executables. This means that
       multiple process can use the same memory to run in. When one tries
       to write to that memory, that page (4KB piece of memory) is copied
       somewhere else. Copy-on-write has two benefits: increasing speed
       and decreasing memory use.
     *  virtual memory using paging (not swapping whole processes) to
       disk: to a separate partition or a file in the filesystem, or
       both, with the possibility of adding more swapping areas during
       runtime (yes, they're still called swapping areas). A total of 16
       of these 128 MB swapping areas can be used at once, for a
       theoretical total of 2 GB of usable swap space. It is simple to
       increase this if necessary, by changing a few lines of source
       code.
     *  a unified memory pool for user programs and disk cache, so that
       all free memory can be used for caching, and the cache can be
       reduced when running large programs.
     *  dynamically linked shared libraries (DLL's), and static
       libraries too, of course.
     *  does core dumps for post-mortem analysis, allowing the use of a
       debugger on a program not only while it is running but also after
       it has crashed.
     *  mostly compatible with POSIX, System V, and BSD at the source
       level.
     *  through an iBCS2-compliant emulation module, mostly compatible
       with SCO, SVR3, and SVR4 at the binary level.
     *  all source code is available, including the whole kernel and all
       drivers, the development tools and all user programs; also, all of
       it is freely distributable. Plenty of commercial programs are
       being provided for Linux without source, but everything that has
       been free, including the entire base operating system, is still
       free.
     *  POSIX job control.
     *  pseudoterminals (pty's).
     *  387-emulation in the kernel so that programs don't need to do
       their own math emulation. Every computer running Linux appears to
       have a math coprocessor. Of course, if your computer already
       contains an FPU, it will be used instead of the emulation, and you
       can even compile your own kernel with math emulation removed, for
       a small memory gain.
     *  support for many national or customized keyboards, and it is
       fairly easy to add new ones dynamically.
     *  multiple virtual consoles: several independent login sessions
       through the console, you switch by pressing a hot-key combination
       (not dependent on video hardware). These are dynamically a
       located; you can use up to 64.
     *  Supports several common filesystems, including minix, Xenix, and
       all the common system V file systems, and has an advanced
       filesystem of its own, which offers filesystems of up to 4 TB, and
       names up to 255 characters long.
     *  transparent access to MS-DOS partitions (or OS/2 FAT partitions)
       via a special filesystem: you don't need any special commands to
       use the MS-DOS partition, it looks just like a normal Unix
       filesystem (except for funny restrictions on filenames,
       permissions, and so on). MS-DOS 6 co pressed partitions do not
       work at this time without a patch (dmsdosfs). VFAT (WNT, Windows
       95) support is available in Linux 2.0 special filesystem called
       UMSDOS which allows Linux to be installed on a DOS filesystem.
     *  read-only HPFS-2 support for OS/2 2.1
     *  HFS (Macintosh) file system support is available separately as a
       module.
     *  CD-ROM filesystem which reads all standard formats of CD-ROMs.
     *  TCP/IP networking, including ftp, telnet, NFS, etc.
     *  AppleTalk server
     *  Netware client and server
     *  Lan Manager (SMB) client and server
     *  Many networking protocols: the base protocols available in the
       latest development kernels include TCP, IPv4, IPv6, AX.25, X.25,
       IPX, DDP (AppleTalk), NetBEUI, Netrom, and others. Stable ne work
       protocols included in the stable kernels currently include TCP,
       IPv4, IPX, DDP, and AX.25.
       
                                                              Reliability
                                                                         
                          The system has to be available 365 days a year.
                                                                         
   The Linux server has proven to be as reliable as any other server
   operating system I have ever used, and more reliable than most. My
   past experience includes managing Novell Netware, Windows NT 3.51 and
   4.0 and Irix (Silicon Graphics) servers. I must say that Novell has
   always been a steady performer, but I have always felt that it was
   more complex than it needed to be. The Silicon Graphics machines were
   always rock solid, but they should be when you pay more than $20,000
   for a single server.
   
   My Linux server was initially setup in January 1997 as a test platform
   to see if it could handle being a production server. At this time I
   had installed a copy of The Cat's Pajamas, Apache, StreamWorks
   (audio/video server) and Samba. Using Samba, I was able to connect the
   Information Systems Department to this server so we could run Cats and
   test the audio/video server. A typical day of testing the system would
   include reindexing and reformatting Cats while serving multiple 100
   megabyte video files and acting as a file server. The Linux machine
   was able to handle all of this while running on only 32 megabytes of
   RAM and using a Pentium 100 CPU.
   
   From January 1997 to July 1997, we experienced only three shutdowns of
   this server, two of which were caused by power failures in the
   building and the third time was due to stupidity on the
   administrator's part. This reliability was a key factor in our
   judgment to use Linux as our server platform.
   
   The installation of NT was simple, and it was easy to get the system
   connected to all the printers, but it proved to be unreliable. We were
   experiencing crashes every day, even after installing service packs
   one and two. I then installed a hot fix to service pack two which was
   to fix errors in the Macintosh services which helped. I was down to
   crashing just one to two times a month. I also tried to run Cats off
   this system, which was a complete disaster since we could not get more
   than five users at a time in Cats, and reports would take forever to
   run.
   
                                                           Cross platform
                                                                         
        The new server must be able to serve the Mac users as well as the
                                                         Windows clients.
                                                                         
   The server must be able to allow connections from Windows and
   Macintosh clients. All major server operating system allow for this,
   including Linux. To server Windows clients, Linux uses a package
   called Samba. Samba is server software for computers running under
   Unix or another Unix-like operating systems with standard TCP/IP
   available. Samba, as it stands right now, depends on Unix file
   structure, permissions, system calls and services. It provides file
   and printer services for clients using some variants of SMB (Server
   Message Block) protocol. SMB is a "native" networking protocol used by
   MS-DOS based (in a very broad sense, including derivatives) clients.
   They include those from IBM, ICL, Microsoft and even one particular
   Novell product. In particular clients are distributed with `Windows
   for Workgroups', `Windows 95', 'Windows NT', 'OS/2 Warp and others.
   
   Some of Samba's server cousins include DEC Pathworks, Microsoft LAN
   Manager/X, OS/2 Lan Manager, IBM LAN Server, Syntax Server and Windows
   NT Server. Some clients such as Windows 95/Workgroups or Warp Connect
   can also act as low volume servers with limited management facilities.
   
   SMB is becoming very popular, mainly owing to these factors:
     *  Windows 95 has dial-up access to PPP servers with an included
       service, and this service allows one to "browse" to public shares
       on the Internet.
     *  Samba is "free" and this is a lot less expensive than Novell!
       (friendlier too!)
     *  With Samba, Unix servers, well connected to a global network,
       can speak in a "native" protocol of clients. It is much simpler to
       maintain one more protocol on a capable server than teach new
       tricks to multiple clients which were never meant to do something
       else.
     *  There is an established, well tested way of doing SMB over
       TCP/IP described in publicly available RFC 1001 and RFC 1002
       documents. This means that SMB has a head start when it comes to
       Internet integration.
       
   
     [INLINE]  On the Macintosh side, Netatalk provides the connectivity
   services. Netatalk is a Unix implementation of the AppleTalk Protocol
   Suite, originally for BSD-derived systems. It includes support for
   routing AppleTalk, serving Unix and AFS file systems over AFP
   (AppleShare), serving Unix printers and accessing AppleTalk printers
   over PAP. A number of other minor printing and debugging utilities are
   also included.
   
                                 Compatibility with Existing Applications
                                                                         
           This server would have to be compatible with The Cat's Pajamas
                                                                         
   When we tried to move to Windows NT, we were given a migration
   guideline from The Cats Pajama's to follow. The instructions were
   simple and the entire migration took little time, but performance was
   terrible. We needed a system that could handle serving the system to
   the network and help maintain the integrity of the Cats data files. I
   have been told that Unix heavily caches file I/O activity (more so
   than Windows NT or Novell Netware), so this added to my hopes that
   Linux would be a strong server platform for Cats, which is a file I/O
   intensive application.
   
   My hopes were verified when we formally flipped the switch on the
   Linux server and turned off the Novell server. Cats ran smoothly and
   gracefully scaled up to the normal daily user level without any
   slowdowns or misfortunes. The Novell Netware server would normally
   experience periods when the system would slow down severely, and then
   speed back up to normal levels after 5 to 10 minutes. During these
   slowdowns, Cat's would become virtually useless, and sometimes users
   would be booted out of Cat's totally.
   
   Another key area that I needed to be compatible with was the world
   Wide Web. I needed to be able to get CGI programs that were already
   tested and in use without having to develop them all myself. I also
   wanted to be able to get help easily and cheaply on setting up the web
   server and fixing it when it breaks. Linux uses Apache, the most
   widely used web server in the world. I can easily get support from
   mailing lists , news groups and Internet BBS's.
   (http://www.netcraft.com/survey/)
   
                                                                    Speed
                                                                         
      After installing the Windows NT server, many users complained about
                               slows access times for the network drives.
                                                                         
   My users equate network drive access speed with network quality. They
   were very pleased with the speed of saving and opening files when they
   were on the Novell Netware server, but expressed disappointment in the
   speed of saving and opening files when we switch to the Windows NT
   server. One way that I have very unscientifically measured the speed
   of the Linux server was when we were using a Windows NT 4.0 machine to
   backup the Cats files off the Linux machine. This operation took 45
   minutes while the exact same operation on the Novell server would take
   at least an hour longer. Currently I am backing up CATS by creating a
   gzipped tar file directly on the Linux server and it takes a little
   less than 45 minutes. Below is part of the output from the df command
   that shows the drive I have Cats on. This shows the current size of
   our Cats installation so you can get an idea of how much information
   is backed up in 45 minutes.
   
   Filesystem 1024-blocks Used Available Capacity Mounted on
   
   /dev/hdc1 2417493 1584580 707923 69% /usr/local/samba-sys
   
                                                              Inexpensive
                                                                         
           I could not afford to go through another costly installation .
                                                                         
   During the twelve months of running Windows NT 4.0 server, I have
   spent more than $3,000 in technical support with Microsoft to remedy
   various problems, including the frequent crashes and problems running
   Cats. The fix for the crashes was always ``Install the latest service
   pack or hot fix and call us back tomorrow.'' The fix for Cats was
   ``Get rid of The Cat's Pajamas and find a better system which was more
   Windows compatible to replace it.'' I wish I would have documented
   that support call with Microsoft so I had the name of the tech rep.
   
   Technical support is no the only area of expense involved with Windows
   NT. The table below shows typical applications and the cost for each
   platform.
   
   Service Microsoft Cost Linux Cost
   Operating System Windows NT Server 4.0 $2,950.00 Linux RedHat 5.0 (CD)
   $49.00
   Web Server Internet Information Server
   
                                                                    $0.00
                                                                         
   Apache
   
                                                                    $0.00
                                                                         
   E-Mail Exchange 5.0 Enterprise
   
                                                                $6,400.00
                                                                         
   Sendmail,UW IMAP,POP-3
   
                                                                    $0.00
                                                                         
   Telnet server SLNet (4 user licensee)
   
                                                                  $300.00
                                                                         
   Included free unlimited licensee
   
                                                                    $0.00
                                                                         
   FTP server Included with IIS
   
                                                                    $0.00
                                                                         
   Included
   
                                                                    $0.00
                                                                         
   Relational Database SQL Server 6.5
   
                                                               $10,650.00
                                                                         
   Just Logic SQL
   
                                                                  $219.00
                                                                         
   Proxy Server Microsoft Proxy Server
   
                                                                  $995.00
                                                                         
   Squid Object Cache
   
                                                                    $0.00
                                                                         
   Backup Software Included
   
                                                                    $0.00
                                                                         
   BRU, included
   
                                                                    $0.00
                                                                         
   Total Cost
   
                                                               $20,995.00
                                                                         
                                                                  $268.00
                                                                         
   Number of Users 100 100
   Cost per seat
   
                                                                  $212.95
                                                                         
                                                                    $2.68
                                                                         
   
   
                                                Low hardware requirements
                                                                         
            I did not want to build the next Cray just to serve 55 users.
                                                                         
   As at most University Press's, our operating budget is relatively
   small, especially when compared to commercial business and some other
   campus departments. This financial restriction did not allow me to
   purchase a server hardware platform that I would have like to have for
   the NT server, but the system was not low-end either.
   
   Our Windows NT 4.0 server:
   OS Windows NT Server 4.0 (SP3)
   CPU 2 x Pentium 150
   RAM 256 Megabytes
   SCSI Adaptec 2940
   -All data drives are SCSI
   -Boot drive is IDE
   Ethernet NE2000 clone Our RedHat Linux 4.2 server:
   OS RedHat 4.2
   CPU Single Pentium 200
   RAM 64 megabytes
   SCSI DPT SmartCache IV
   -RAID Station 3 (RAID 5)
   -Boot drive is IDE
   Ethernet NE2000 clone The RAID which is listed on the Linux server was
   not purchased strictly for the Linux server, but was purchased to be
   placed on whatever server we decided to put into production.
   
                                                   Ease of administration
                                                                         
                                                   For myself and staff .
                                                                         
   
   [INLINE] Unix usually gets the standard rap of being difficult to
   manage and requiring a steep learning curve. While many of the tools
   that will be used to manage the system are still command line based, a
   growing number are graphical and comparable to Windows in ease of use.
   This is especially true with the RedHat distribution, which includes a
   graphical control panel which allows the administrator to change
   system setting without working through the many text files which store
   this information. The control panels I use the most are the ones which
   setup the printers, file system, users and packages. If you use the
   included RedHat Package manager to install new applications, they are
   listed in the package manager, which allows you to graphically see
   what applications are installed on your system and remove them if
   wanted, much like the uninstall option on Microsoft Windows.
   
   [INLINE] [INLINE]
   
                                                      Simple upgrade path
                                                                         
            I don't want to start over each time a new version comes out.
                                                                         
   RedHat Linux provides a very simple upgrade system in its installation
   set. The upgrade is actually better than the Microsoft Windows NT
   upgrade path, since you do not have to uninstall the previous version
   first.
   
   While it is not required that you uninstall the previous version of
   Windows NT before installing the current release (4.0), it is
   recommended. This can be a very intensive installation, since you
   would need to setup all the user accounts again, along with
   reinstalling any software and automated systems and scripts.
   
   When I upgraded from RedHat 4.1 to 4.2, the installation when smoothly
   whiteout any problems. While this was not a major revision step,
   RedHat has assured me that the soon to be released version 5.0 will
   offer a smooth transition from 4.2.
   
   From the RedHat Linux manual:
   
   
                     1.5 Upgrading from a Prior Version
                                      
   The installation process for Red Hat Linux 4.2 includes the ability to
    upgrade from prior versions of Red Hat Linux (2.0, 2.1, 3.0.3, 4.0,
     and 4.1) which are based on RPM technology. Upgrading your system
    installs the modular 2.0.x kernel as well as updated versions of the
     packages which are installed on your machine. The upgrade process
     preserves existing configuration files using a .rpmsave extension
    (e.g., sendmail.cf.rpmsave) and leaves a log telling what actions it
      took in /tmp/upgradelog. As software evolves, configuration file
     formats can change, so you should carefully compare your original
   configuration files to the new files before integrating your changes.
                                      
     To upgrade a Red Hat Linux system, you must use a boot floppy (and
   possibly a supplemental floppy), just as if you were performing a full
    install. After selecting the medium to install from (and setting up
    networking information if it's required), the installation procedure
   prompts you to either Install or Upgrade; select Upgrade. This upgrade
    procedure is the functional equivalent of running the upgrade script
               in prior versions of Red Hat Linux.  [INLINE]
                                      
      Please note that some upgraded packages may ``depend'' on other
      packages which may not be installed on your system. The upgrade
   procedure takes care of these dependencies, but it may need to install
               additional packages in order to satisfy them.
                                      
   
   
   
                                        Remote control and administration
                                                                         
   One of the most attractive features of Linux (or Unix in general) is
   the ability to truly remotely control the server. Since Linux comes
   with a telnet server built in, you can use virtually any computer,
   regardless of operating system to telnet into the computer to do all
   administrative tasks. To remotely administer a Windows NT server, you
   must purchase a separate application to allow remote control. The most
   popular program for this is PCAnywhere by Symantec. This approach can
   become costly because you must purchase a copy for the server to act
   as the host, and a copy for each computer that needs to remotely
   control the server. How many remote computers need to control the
   server? This depends on each installation, but I have found that it
   save me a lot of running by having the ability to control the server
   from every PC on my network, and from home.
   
   Telnet is text only, so this will be a drawback for many, but luckily
   for us, Linux supports X Windows. X Windows can be used locally on the
   server's console, like Windows NT, but can also be run remotely from
   any computer that can run an X client. These remote terminals can by
   other computers running Linux, or any other flavor of Unix and many X
   clients can be downloaded or purchased for Windows, Windows NT and
   Macintosh computers. Running X terminals does require more bandwidth,
   so I prefer just telneting into the server.
   
   Another nice feature is the ability to display results of various
   system utilities in a web page. One of the things our Customer Service
   manager likes to know is which users have which files open and locked
   while using Cats. I wrote a simple Perl script to run the smbstatus
   program and print the results as a web page.
   
   The output web page:
   
   Snapshot of users for: Fri Dec 5  
   
   11:41:18 CST 1997  
   
   This page shows currently logged on users and locked files for the
   UNPLINUX server.
   Right-click this page and select REFRESH or RELOAD to force an
   update
   
   Samba version 1.9.17p1
   Service uid gid pid machine
   ----------------------------------------------
   cdrom root root 11697 enterprise (129.93.31.35) Thu Dec 4 16:35:23
   1997
   quinn root root 11697 enterprise (129.93.31.35) Thu Dec 4 16:35:23
   1997
   M-DATA cbrumm cbrumm 11435 ds9 (129.93.31.14) Thu Dec 4 16:08:16
   1997
   programs root root 11697 enterprise (129.93.31.35) Thu Dec 4 16:35:23
   1997
   L-NE cbrumm cbrumm 11435 ds9 (129.93.31.14) Thu Dec 4 16:08:29 1997
   N-DBC cbrumm cbrumm 11435 ds9 (129.93.31.14) Thu Dec 4 16:08:29 1997
   O-WORK cbrumm cbrumm 11435 ds9 (129.93.31.14) Thu Dec 4 16:08:29
   1997
   P-HIST cbrumm cbrumm 11435 ds9 (129.93.31.14) Thu Dec 4 16:08:29
   1997
   
   <snip>
   
   Locked files:
   Pid DenyMode R/W Name
   ------------------------------
   19818 DENY_NONE RDWR fileauth.txt Fri Dec 5 11:41:14 1997
   21212 DENY_NONE RDWR fileauth.txt Fri Dec 5 11:40:28 1997
   20590 DENY_NONE RDWR fileauth.txt Fri Dec 5 11:38:56 1997
   21384 DENY_NONE RDWR fileauth.txt Fri Dec 5 11:06:15 1997
   
   <snip>
   
   19818 DENY_NONE RDWR filebac2.isi Fri Dec 5 11:02:36 1997
   20590 DENY_NONE RDWR filebac2.isi Fri Dec 5 10:14:44 1997
   19818 DENY_NONE RDWR fileauth.isi Fri Dec 5 11:41:14 1997
   21212 DENY_NONE RDWR fileauth.isi Fri Dec 5 11:40:28 1997
   
   Share mode memory usage (bytes):
   92584(90%) free + 7728(7%) used + 2088(2%) overhead = 102400(100%)
   total
   
   The script that generates the above page:
   
   #!/usr/bin/perl
   # ******************************************************
   # * *
   # * Author: Quinn P. Coldiron *
   # * Date: 12-1-97 *
   # * Program: This program shows current users of the *
   # * Samba server. *
   # * *
   # ******************************************************
   # Use cgi-lib CGI library for PERL.
   
   require "/home/httpd/cgi-bin/cgi-lib.pl";
   $date = `date`;
   $users = `./smbstatus`;
   #Get the data from the form.
   
   &ReadParse;
   print &PrintHeader;
   print "<HTML>\n";
   print "<HEAD>\n";
   print "<TITLE>Logged In Samba Users</TITLE>\n";
   print "</HEAD>\n";
   print "<BODY BGCOLOR= #D4D4D4>\n";
   print "<H1>Snapshot of users for: $date</H1>\n";
   print "This page shows currently logged on users and locked files for
   the UNPLINUX server.<br>\n";
   print "Right-click this page and select REFRESH or RELOAD to force an
   update<br>\n";
   print "<PRE>$users</PRE>\n";
   print "</BODY>\n";
   print "</HTML>\n";
   
   Windows NT provides a graphical program to show a chart us system
   performance, but it is recommended that you do not run it on the
   server that you want to monitor, because the monitor program itself
   takes too much of the system resources, and thus skews the data. Linux
   provides a system monitoring tool called TOP that is character based
   so it can be run on the server. Since it is character based, you can
   telnet into the server and run it from anywhere, getting an accurate
   picture of how the server is running.
   
   Sample output of TOP:
   
   11:55am up 1 day, 15:02, 3 users, load average: 0.08, 0.04, 0.00
   83 processes: 82 sleeping, 1 running, 0 zombie, 0 stopped
   CPU states: 2.7% user, 4.2% system, 5.9% nice, 93.7% idle
   Mem: 63204K av, 62336K used, 868K free, 38384K shrd, 5536K buff
   Swap: 114908K av, 368K used, 114540K free 29496K cached
   
   PID USER PRI NI SIZE RSS SHARE STAT LIB %CPU %MEM TIME COMMAND
   22390 root 10 0 540 540 400 R 0 2.8 0.8 0:00 top
   22388 cats 3 0 848 848 516 S 0 1.5 1.3 0:00 login
   22391 cats 10 0 660 660 524 S 0 0.7 1.0 0:00 bash
   6058 root 1 0 3568 3568 1396 S 0 0.5 5.6 1:25 tkdesksh
   22283 root 0 0 552 552 424 S 0 0.3 0.8 0:00 in.telnetd
   22387 root 1 0 552 552 424 S 0 0.3 0.8 0:00 in.telnetd
   21212 quinn 0 0 1084 1084 660 S 0 0.1 1.7 0:02 smbd
   20921 root 1 0 588 536 356 S 0 0.1 0.8 0:08 SWserver
   1 root 0 0 312 312 244 S 0 0.0 0.4 0:02 init
   2 root 0 0 0 0 0 SW 0 0.0 0.0 0:01 kflushd
   3 root -12 -12 0 0 0 SW< 0 0.0 0.0 0:00 kswapd
   19509 root 0 0 1092 1092 652 S 0 0.0 1.7 0:18 smbd
   331 root 0 0 812 812 480 S 0 0.0 1.2 0:00 login
   21 root 0 0 280 280 216 S 0 0.0 0.4 0:00 kerneld
   240 root 0 0 336 316 280 S 0 0.0 0.4 0:00 gpm
   128 root 0 0 368 360 276 S 0 0.0 0.5 0:00 syslogd
   137 root 0 0 496 488 268 S 0 0.0 0.7 0:00 klogd
   
        _________________________________________________________________
                                                                         
                                                                Section 3
                                                                         
                                                           Under the Hood
                                                                         
                                                    Setting up the server
                                                                         
                                                       Linux installation
                                                                         
   The actual installation of an operating system is often used as a
   judgement on how good the system is. Just as with meeting people, you
   can never change the first impression. I have found that setting up a
   RedHat Linux server is as easy or even easier than setting up a
   Windows NT server. The setup includes two floppies have everything
   needed to get the system to the point that it can recognize the media
   (CDROM, FTP site, other server, etc.) that the installation files are
   on. Windows NT supplies three floppies for this purpose, but only
   supports CDROM installation. I have found that installing RedHat Linux
   on a laptop can even be easier, since it can detect the PCMCIA slots
   at installation time, while NT cannot. The most important factor is to
   be familiar with the hardware you have installed in your machine,
   including:
     *  hard drive(s): number and size; if you have more than one, it's
       helpful to know which one is first, second, etc.
     *  memory: amount of RAM.
     *  CD-ROM: its interface type (IDE, SCSI, or other interface), and,
       for non-IDE, non-SCSI CD-ROMs, the make and model number.
     *  SCSI adapter: make and model number.
     *  network card: make and model number.
     *  mouse: type (serial, PS/2, or bus mouse), protocol (Logitech,
       Microsoft, MouseMan, etc.), and number of buttons; also, for
       serial mice, the com port it is connected to.
     *  If you will be connected to a network, be sure you know your IP
       address, netmask, gateway IP address, name server IP addresses,
       domain name, and hostname. If you don't know these values, ask
       your network administrator.
     * Also, if you will be installing the X Window System, you should be
       familiar with the following:
     *  your video card: make and model number or video chipset, amount
       of video RAM.
     *  your monitor: make and model number, allowable range of
       horizontal and vertical refresh rates.
       
   You can install or upgrade Red Hat Linux/Intel via any of several
   basic methods. Depending on the method you use, you need either one or
   two formatted high-density (1.44 MB) 3.5-inch diskettes.
   
   Installing from CD-ROM or via NFS requires only a boot diskette.
   Installing from a hard drive, via FTP, from an SMB volume, or from a
   PCMCIA device (including PCMCIA-based CD-ROMs) requires both a boot
   diskette and a supplemental diskette. Section 2.3.1 below explains how
   to create boot and supplemental diskettes.
   
   CD-ROM
   
   If you have a Red Hat Linux CD and a boot diskette you will need a
   supported CD-ROM drive and either a 3.5 inch floppy drive or an
   operational installation of MS-DOS on your machine in order to run the
   installation utility. If a boot diskette did not accompany your CD,
   you will need access to a computer running either Linux or MS-DOS to
   create a boot diskette from the CD.
   
   NFS
   
   If you wish to install over a network, you will need to mount the Red
   Hat Linux CD-ROM on a machine that supports ISO-9660 file systems with
   Rock Ridge extensions. The machine must also support NFS. Export the
   CD-ROM file system via NFS. You will need to have name services
   configured, or know the NFS server's IP address, and the path to the
   exported CD-ROM.
   
   FTP
   
   For an FTP install, you must have a boot disk and supplemental disk.
   You will need to have a valid name server configured or the IP address
   of the FTP server you will be using. You will also need the path to
   the root of the Red Hat Linux directory on the FTP site.
   
   SMB Shared Volume
   
   If you wish to install from an SMB shared volume, you will need to
   mount the Red Hat Linux CD-ROM on a Microsoft Windows NT or Windows 95
   server that supports shared volumes. You will need to have name
   services configured, or know the server's IP address; you will also
   need the name of the shared volume containing the Red Hat Linux CD-ROM
   and the account number and password to use to access the volume.
   
   Hard Drive
   
   To install Red Hat Linux from a hard drive you will need the same boot
   and supplemental disks used by the FTP install. You must first create
   a RedHat directory at the top level of your directory tree. Everything
   you will install should be placed in that directory. First copy the
   base subdirectory, then copy the packages you want to install to
   another subdirectory called RPMS. You can use available space on an
   existing DOS partition or a Linux partition that is not required in
   the install procedure (for example, a partition that would be used for
   data storage on the installed system).
   
   If you are using a DOS filesystem, you may not be able to use the full
   Linux filenames for the RPM packages. The installation process does
   not care what the filenames look like, but it is a good idea that you
   keep track of them so you will know what you are installing.
   
   PCMCIA
   
   If your CD-ROM, Ethernet card, or local hard disk is connected to a
   PCMCIA adapter, you must install with PCMCIA support. You need a
   supported PCMCIA controller and a supported PCMCIA SCSI adapter or
   Ethernet card. Installing via PCMCIA requires the use of a
   supplemental diskette.
   
   Please See Appendix A for The Official RedHat Installation Guide.
   
                                                 Samba Installation/Setup
                                                                         
   Installing the Samba RPM is the easiest way to install, as you only
   need to download the file and type rpm -I filename and it is
   installed. Setting up Samba is simple, as you just edit a text file to
   tell it what directories are going to be shared to the Windows
   clients. The text file's name is smb.conf and is located in the /etc.
   directory if you installed Samba using RPM. If you downloaded the .tar
   archive and installed Samba using the default installation, you will
   find the smb.conf file in /usr/local/samba/lib/.
   
   An advantage to installing Samba using RPM is that it is easier. A
   disadvantage is that the versions are not as current, but they are
   usually more stable and reliable. I choose to go directly to the Samba
   web pages and download the most current non-beta release.
   
   The picture on the left is the Network Neighborhood window on my NT
   workstation and is currently showing everything that I have access to
   on my Linux server.
   
   If you installed Samba using RPM, it will automatically be started on
   system startup, but I had to manually add it to my rc.local script to
   have it start on bootup because I did not install from the RPM. I
   chose to install from the tarballs available at the official Samba
   site, so I could always have a current installation. To start the
   server manually, I just issue these commands:
   
   /usr/local/samba/bin/smbd -D
   
   /usr/local/samba/bin/nmbd -D
   
   Extensive has been accomplished that allows Samba to act more like an
   NT server, including making a Linux server a Primary Domain Controller
   and more features are currently being added. I have listed the steps
   that I took in making my Linux server the Primary Domain Controller
   (PDC) for our network.
   
   1. Set up the server.
          a. Create the smb.conf file.
          b. Create the netlogon directory. I put mine in /home.
          c. Restart Samba.
   
   2. Setup the Windows 95 clients. (We set our up for roaming profiles.)
   Do not reboot until step 3!
          a. Control Panel
                  1. Click Passwords, then Profiles and choose these
   settings:
                          a. Users can customize their settings.
                          b. Include desktop items.
                          c. Include start menu.
                  2. In the Control Panel, select Network.
                          a. Under Identification, set your WORKGROUP
   name.
                          b. Access control = USER-LEVEL.
                          c. Obtain the list from YOUR SERVER NAME.
                          d. Under Client Configuration
                                  1. Select CLIENT FOR MICROSOFT
   NETWORKS.
                                  2. Under that client's properties.
                                          a. Log onto Windows NT domain.
                                          b. Enter your WORKGROUP name.
                                          c. Select LOG ON AND RESTORE
   CONNECTIONS.
                          e. Set primary network logon to CLIENT FOR
   MICROSOFT NETWORKS.
          b. Set up the user profiles.
                  1. Install the Policy Editor from the Windows 95 CD.
                  2. Create a new profile called config.pol and save it
   into the NETLOGON share on the Linux server. Make sure you add all the
   users on your server! This step only has to be
                      done once, not on each client.
                  3. Using the Policy Editor, select Open registry from
   the File menu and select the options you want.
                  4. Save it as config.pol and copy into the netlogon
   share on the Linux server. Set its permissions as 755.
   
   3. Reboot the Windows 95 computer(s) and logon.
   
   4. Possible problems.
          1. Windows95 OSR2 seems to send the passwords as uppercase, so
   try changing the passwords on the Linux server to uppercase.
          2. I had problems making my Linux server the WINS server, so
   you have some choices to fix this:
                  a. If you do have another NT server, make it the WINS
   server and point all the clients to it.
                  b. Disable WINS on each client and edit the
   c:\windows\Lmhosts.sam file and add the server and workstations to
   this file. Save the file as Lmhosts, NOT Lmhosts.sam This file can be
   appended to from a server, but
                      I haven't tried doing it from Linux/Samba. The
   entries look like this: xxx.xxx.xxx.xxx computername
                  c. Disable WINS. At this time, we are running our Win95
   clients with WINS disabled, but we do have a DNS server.
   
   My Samba configuration (smb.conf) file looks like this:
   
   ; *******************************************************************
   ; *
   ; * Samba config file for UNPLINUX
   ; * Quinn P. Coldiron
   ; *
   ; *******************************************************************
   [global]
   workgroup = UNP
   comment = Unplinux Server
   volume = RedHat5
   lock directory = /var/lock/samba
   locking = yes
   strict locking = no
   share modes = yes
   security = user
   os level = 65
   domain master = yes
   local master = yes
   prefered master = yes
   domain logons = yes
   wins support = yes
   ;logon script = %m.bat ; per workstation (machine)
   ;logon script = logon.bat
   logon script = %U.bat
   preserve case = yes
   short case preserve = yes
   case sensitive = no
   ; printing = BSD or SYSV or AIX, etc..
   printing = bsd
   printcap name = /etc/printcap
   load printers = yes
   print command = /usr/bin/lpr -r -P %p %s
   [netlogon]
   comment = Samba Network Logon Service
   path = /home/netlogon
   case sensitive = no
   guest ok = yes
   locking = no
   read only = yes
   browseable = yes ; say NO if you want to hide the NETLOGON share
   ;admin users = @wheel
   create mode = 0755
   
   ;
   ######################################################################
   #########
   ; # #
   ; # Printers #
   ; # #
   ;
   ######################################################################
   #########
   ; I couldn't get the generic printers section to work, so I commented
   it out
   ; and explicitly declared the printers.
   ;[printers]
   ; comment = All Printers
   ; path = /var/spool/samba-print
   ; browseable = yes
   ; printable = yes
   ; Set public = yes to allow user 'guest account' to print
   ; public = no
   ; writable = no
   ; create mode = 0700
   
   [Technology]
   comment = Technology Printer
   path = /var/spool/samba-print
   print = Technology
   browseable = yes
   printable = yes
   public = yes
   writeable = yes
   create mode = 0777
   
   [Marketing2]
   comment = Technology Printer
   path = /var/spool/samba-print
   print = Marketing2
   browseable = yes
   printable = yes
   public = yes
   writeable = yes
   create mode = 0777
   
   [Marketing1]
   comment = Technology Printer
   path = /var/spool/samba-print
   print = Marketing1
   browseable = yes
   printable = yes
   public = yes
   writeable = yes
   create mode = 0777
   
   [CustServ]
   comment = Technology Printer
   path = /var/spool/samba-print
   print = CustServ
   browseable = yes
   printable = yes
   public = yes
   writeable = yes
   create mode = 0777
   
   [CanonColor]
   comment = Color Laser Printer
   path = /var/spool/samba-print
   print = CanonColor
   browseable = yes
   printable = yes
   public = yes
   writeable = yes
   create mode = 0777
   
   ;
   ######################################################################
   #########
   ; # #
   ; # Shared Volumes #
   ; # #
   ;
   ######################################################################
   #########
   
   [homes]
   comment = Home Directories
   browseable = no
   writable = yes
   read only = no
   preserve case = yes
   short preserve case = yes
   ;create mode = 0777
   
   [userdata]
   comment = All userdata that you are allowed to see.
   path = /home
   writeable = yes
   ;Full control for your stuff, full in you group, nothing for other
   ;people's stuff.
   create mode = 0770
   
   [sys]
   comment = System drive. Various Press utilities.
   path = /usr/local/samba-sys/
   writeable = yes
   create mode = 0777
   
   [programs]
   comment = Program drive. Installation sets and programs.
   path = /usr/local/samba-programs
   writeable = yes
   create mode = 0777
   
   [ulrich]
   comment = Ulrich's PLUS.
   path = /usr/local/samba-programs/ulrich
   create mode = 555
   
   [cdrom]
   comment = Internal IDE cdrom. For temporary usage.
   path = /mnt/cdrom
   
   [dictionary]
   comment = Random House Dictionary.
   path = /mnt/scd1
   
   [bip]
   comment = Bowker Books In Print CDROM
   path = /mnt/scd0
   
   [msoffice]
   comment = Microsoft Office Bookshelf Reference.
   path = /mnt/scd3
   
   [encarta]
   comment = Microsoft Encarta
   path = /mnt/scd2
   
   [press]
   comment = Press share. Marketing maps this to U:
   path = /home/press
   writeable = yes
   create mode = 0777
   
   [CATS-VOL]
   comment = Entire Cats volume for backup
   path = /usr/local/samba-cats/
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [L-NE]
   comment = Cat's root. Map as L.
   path = /usr/local/samba-cats/ne
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [M-DATA]
   comment = Cat's data drive. Map as M.
   path = /usr/local/samba-cats/ne/data
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [N-DBC]
   comment = Cat's program drive. Map as N.
   path = /usr/local/samba-cats/ne/dbc
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [O-WORK]
   comment = Cat's work drive. Map as O.
   path = /usr/local/samba-cats/ne/work
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [P-HIST]
   comment = Cat's history drive. Map as P.
   path = /usr/local/samba-cats/ne/hist
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
     My actual logon.bat batch file is here:
   
   REM *******************************************************
   REM * *
   REM * University of Nebraska Press network logon script. *
   REM * *
   REM * Last modified : 10-16-97 *
   REM * By: Quinn *
   REM * *
   REM * The drive letter scheme is leftover from the past *
   REM * network administrator and the Novell Netware 3.1 *
   REM * server he had. *
   REM *******************************************************
   REM User's home drives
   net use e: \\unplinux\homes
   REM General network drives
   net use f: \\intrepid\sys
   net use g: \\intrepid\userdata
   net use h: \\intrepid\dictionary
   net use i: \\intrepid\bip
   net use j: \\intrepid\programs
   net use s: \\unplinux\ulrich
   REM CATS drives
   net use l: \\unplinux\l-ne
   net use m: \\unplinux\m-data
   net use n: \\unplinux\n-dbc
   net use o: \\unplinux\o-work
   net use p: \\unplinux\p-hist
   REM Temp entry for Robotronics
   REM The old system had robo on the T:\ drive but
   REM all new installations will run robo from the j:\ drive.
   net use t: \\unplinux\programs
   
   
                                              Netatalk Installation/Setup
                                                                         
   Netatalk offers the same installation options as Samba, so you can
   choose either the RPM, or .tar archives. I would choose the RPM here,
   as they are the same versions as the .tar files and make life easier
   during installation. I really don't have mush to say about this
   installation, since it was very simple and straight forward. After
   installing the package, I just edited the AppleVolumes.system file and
   started the daemon. Below is a very simple AppleVolumes.system file
   that will give the Mac users their home directory and a few other
   volumes that might have stuff they need.
   
   
   #
   # This file is read before (after if -u is specified) the user's
   # AppleVolume file. Add extension mappings and volumes here.
   #
   /usr/local/samba-sys Sys (F drive)
   /home Userdata (G drive)
   /usr/local/samba-programs Programs (J drive)
   # default translation -- note that CR <-> LF translation is done on
   all
   # files of type TEXT. The first line turns off translation for files
   of
   # unknown type, the second turns this translation on.
   . BINA UNIX
   # . TEXT UNIX
   # sounds
   .mod STrk STrk
   .mid Midi ttxt
   .aiff AIFF SNdm
   .wav WAVE SNdm
   .au ULAW SNdm
   # video
   .moov MooV mMPG
   .mov MooV mMPG
   .mpg MPEG mMPG
   .mpeg MPEG mMPG
   # formatted text
   .html TEXT MOS!
   .rtf TEXT MSWD
   .doc WDBN MSWD
   # compressed archives
   .bin BINA MB2P
   .zip ZIP ZIP
   .tar TARF TAR!
   .gz Gzip Gzip
   .Z ZIVM LZIV
   .sea ???? SITx
   .cpt PACT CPCT
   .sit SIT! SIT!
   .hqx TEXT SITx
   # graphics
   .tiff TIFF JVWR
   .tif TIFF JVWR
   .bmp BMPp JVWR
   .pct PICT ttxt
   .pict PICT ttxt
   .jpeg JPEG JVWR
   .jpg JPEG JVWR
   .gif GIFf JVWR  The other file that you need to edit with NetaTalk is
   papd.conf. This file hold the printer information.
   
   # Attributes are:
   #
   # Name Type Default Description
   # pd str ".ppd" Pathname to ppd file.
   # pr str "lp" LPD printer name.
   # op str "operator" Operator name, for LPD spooling.
   #
   # Some examples:
   #
   # On many systems (notably not Solaris), no papd.conf is required,
   # since papd shares the same defaults as lpd.
   #
   # A simple example:
   #
   # terminator:\
   # :pr=lp:op=wes:\
   # :pd=/usr/share/lib/ppd/HPLJ_4M.PPD:
   #
   # Note also that papd.conf can list several printers.
   
   
                                              Installing The Cats Pajamas
                                                                         
                                            Installing Cats on the Server
                                                                         
   Installing Cats on a Linux server can be as simple as copying all the
   files and directories from the old server to the Linux server's shared
   volume for Cats. The way that I set up out server was to install
   another drive in the Linux server to hold the Cats installation. I
   chose an IDE drive mainly because I didn't have a SCSI card in the
   server, didn't have an extra one handy and I was under an extreme time
   crunch to get Cats back online. My intentions were to eventually
   replace the IDE drive with a SCSI drive over Christmas break, but the
   performance has been more than satisfactory, so we are going to leave
   the setup alone. I mount this drive as /usr/local/samba-cats and have
   the permissions set open to the world by running the command chmod 777
   /usr/local/samba-cats -R. This is a security risk, but Cats has told
   me that the files must be world writeable and readable for Cats to
   work properly. I also have the Samba configuration file set up with a
   mask of 0777, which will make sure that all files written will be
   readable by all the users.
   
   The specific portion of the smb.conf file for Cats is listed here:
   
   [CATS-VOL]
   comment = Entire Cats volume for backup
   path = /usr/local/samba-cats/
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [L-NE]
   comment = Cat's root. Map as L.
   path = /usr/local/samba-cats/ne
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [M-DATA]
   comment = Cat's data drive. Map as M.
   path = /usr/local/samba-cats/ne/data
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [N-DBC]
   comment = Cat's program drive. Map as N.
   path = /usr/local/samba-cats/ne/dbc
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [O-WORK]
   comment = Cat's work drive. Map as O.
   path = /usr/local/samba-cats/ne/work
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777
   
   [P-HIST]
   comment = Cat's history drive. Map as P.
   path = /usr/local/samba-cats/ne/hist
   writeable = yes
   printable = no
   guest ok = yes
   public = yes
   create mask = 0777  At the time of this writing, we were still running
   Cats 2.3, so the major directories were as follows:
   
   ne----+
        |---> data
        |---> dbc
        |---> work
        |---> hist  While we are currently able to get all of our system
   onto a 2.5 gigabyte hard drive, I can see a day when we will have a
   large enough history that we will need more space. We could just get a
   larger hard drive, but an easier upgrade would be to just add another
   drive and mount it into the directory tree. We could actually run four
   drives for Cats by mounting a different drive into the ne directory
   for each subdirectory. By doing this, data would be running on a
   drive, dbc would be a drive, work would be a drive and hist would be a
   drive. In theory, the performance would increase, since drive access
   to data would not slow down history searches, or read/writes to the
   work drive.
   
   I have written a CGI Perl script to make it simple for our Business
   Department and Customer service department to lock Cats during
   month-end closing and reindexing procedures. The script asks for a
   password, and then replaces the standard batch files to start Cats
   with another batch file that says Cats is locked for closing or
   maintenance. When they are finished, they can unlock Cats by running
   the unlock CGI script. The scripts are listed here:
   
   Lock Cats:
   #!/usr/bin/perl
   # ******************************************************
   # * *
   # * Author: Quinn P. Coldiron *
   # * Date: 11-24-97 *
   # * Program: This locks Cats *
   # * *
   # ******************************************************
   # Use cgi-lib CGI library for PERL.
   require "/home/httpd/cgi-bin/cgi-lib.pl";
   #Get the data from the form.
   &ReadParse;
   print &PrintHeader;
   print "<HTML>\n";
   print "<HEAD>\n";
   print "<TITLE>Finished</TITLE>\n";
   print "</HEAD>\n";
   print "<BODY BGCOLOR= #b7b7b7>\n";
   if ( $in{password} =~ "PASSWORD") {
   print "<P><B>Finished.</B></P>\n";
   print "<P>Batch files written and CATS is <B>locked</B>.</P>\n";
   print "<BR>You may access CATS by going to the M: drive and typing
   secret.bat\n";
   print "This should only be used for Month-end closing, reindexing and
   system repairs.\n";
   print "<BR><BR>Quinn.\n";
   system ("cp /home/httpd/cgi-bin/cats/lock/*.bat
   /usr/local/samba-cats/ne/data/");
   system ("chmod 777 /usr/local/samba-cats/ne/data/*");
   } else {
   print "Wrong password\n";
   }
   print "</BODY>\n";
   print "</HTML>\n";  Unlock Cats:
   
   #!/usr/bin/perl
   # ******************************************************
   # * *
   # * Author: Quinn P. Coldiron *
   # * Date: 11-24-97 *
   # * Program: This program copies that cats#.bat files *
   # * to the correct location. *
   # ******************************************************
   # Use cgi-lib CGI library for PERL.
   require "/home/httpd/cgi-bin/cgi-lib.pl";
   #Get the data from the form.
   &ReadParse;
   print &PrintHeader;
   print "<HTML>\n";
   print "<HEAD>\n";
   print "<TITLE>Finished</TITLE>\n";
   print "</HEAD>\n";
   print "<BODY BGCOLOR= #b7b7b7>\n";
   if ( $in{password} =~ "PASSWORD") {
   print "<P><B>Finished.</B></P>\n";
   print "<P>Batch files written and CATS is unlocked.</P>\n";
   print "<BR><BR>Quinn.\n";
   system ("cp /home/httpd/cgi-bin/cats/unlock/*.bat
   /usr/local/samba-cats/ne/data/");
   system ("chmod 777 /usr/local/samba-cats/ne/data/*");
   } else {
   print "Wrong password!\n";
   }
   print "</BODY>\n";
   print "</HTML>\n";
   
   
                                         Configuring your Windows clients
                                                                         
   I have setup our Cats installation to share each required cats
   directory as a hard mounted drive letter. The specific portion of the
   login script that mounts cats is listed here:
   
   REM CATS drives
   net use l: \\unplinux\l-ne
   net use m: \\unplinux\m-data
   net use n: \\unplinux\n-dbc
   net use o: \\unplinux\o-work
   net use p: \\unplinux\p-hist  My cats batch file is here:
   
   PATH=C:\;C:\WINNT;C:\WINDOWS;L:\;M:\;N:\;O:\;P:\
   SET DBC_FILEPATH=L:\;M:\;N:\;O:\;P:\
   Set DBC_PREP=M:
   Set DBC_FILES=140
   Set DBC_PGMSIZE=65024
   Set DBC_CMDLINE=OLD
   SET DBC_XKEYS=ON
   Set DBC_COMPAT=DOS
   Set DBC_PORT=24
   SET DBC_DBCPATH=N:\
   M:
   DBC.EXE  I have also followed the suggestions on the Cats web site
   http://www.tcpj.com for specific settings for Windows 95. I have found
   that all of these do help in getting Cats to run better.
   
                                 Configuring the DOS emulator to run Cats
                                                                         
   Linux has a very interesting program called DOSEMU which creates a
   ``DOS box'' that can run many DOS applications, including MS-DOS,
   PC-DOS, DR DOS, Open DOS, Windows for Workgroups 3.11, the Novell
   Netware client and many more. I had problems at first getting DOSEMU
   to run programs on the redirected drives unless I called them by the
   full name (go.bat instead of go) but tracked this down to the version
   of DOS that I was using. I was using Novell DOS 7.0 but switched to
   MS-DOS 6.22 on the advice of Hans Lermen (one of the DOSEMU
   developers) and this fixed the problem. He said that this has been
   reported many times and it seems to be a bug in the command.com code
   that many versions of non Microsoft DOS use.
   
   DOSEMU uses an image file of a hard disk to emulate a DOS hard drive
   so you do not need to have a DOS partition. Using the
   /var/lib/dosemu/setup-hdimage program will step you through making a
   basic hdimage file. The only required item is a bootable DOS 6.22
   floppy disk with whatever DOS tools you think you might need. I
   included EDIT.COM and QBASIC.EXE. After running through the
   setup-hdimage program, start the emulator with xdos or dos, depending
   on if you are in X-Windows or not. The default setup gives you the
   Linux hard drive as DOS drive D:\. To copy the programs I wanted off
   the floppy to the hdimage file, I opened another xterm window and
   mounted the floppy to /mnt/floppy, then switched back to DOSEMU,
   changed to D:\mnt\floppy and copied EDIT.COM and QBASIC.EXE to C:\. I
   could now run the MS-DOS editor to edit the config.sys and
   autoexec.bat files. If I wanted, I could also write a quick QBASIC
   program.
   
   DOSEMU gives you a utility called LREDIR which redirects Linux
   directories to DOS drive letters. Below is the AUTOEXEC.BAT that I use
   with DOSEMU to give me the drive letters for Cats and for Robotronics.
   
   @echo off
   path=c:\;l:\;m:\;n:\;o:\;p:\
   prompt $p$g
   rem set temp=c:\temp
   lredir l: linux\fs\usr\local\samba-cats\ne
   lredir m: linux\fs\usr\local\samba-cats\ne\data
   lredir n: linux\fs\usr\local\samba-cats\ne\dbc
   lredir o: linux\fs\usr\local\samba-cats\ne\work
   lredir p: linux\fs\usr\local\samba-cats\ne\hist
   lredir t: linux\fs\usr\local\samba-sys\programs\nesb
   c:
   menu.bat  This autoexec.bat file loads the redirected drives and
   displays a menu which allows the user to select the DOS application
   they want to run (CATS and Robotronics). I have set the dos emulator
   as the shell, so that as soon as the Mac users or remote users telnet
   into the Linux server the DOS emulator is started and they get the
   main menu. When they exit the DOS emulator, they are disconnected from
   the server.
   
                                                        Installing a RAID
                                                                         
   [LINK]The RAID that we chose to purchase was a kit that contained a
   SCSI RAID controller and subsystem storage cabinet from Distributed
   Processing Technology.
   
   The SCSI card is a PCI card with a caching module added to it. The
   cache module has four SIMM slots on it and will accept any standard 32
   pin SIMM up to 16 meg each for a total of 64 megabytes of cache. The
   card comes with a four meg module already installed, and that is what
   we currently are using.
   
   The storage subsystem requires you to supply your own drives and comes
   in two style. One supports narrow SCSI drives and the other supports
   wide drives. We are using the narrow drive cabinet, mainly because I
   already had three drives that I wanted to use. Installing the drives
   can be tricky, as the data cable is not color coded and I could not
   tell what wire was for pin one. The first time around I had the drives
   installed backwards, but nothing was hurt. I called the tech support
   line and they were very helpful in getting the problem fixed.
   
   After installing the card in the server, the next step is to configure
   the RAID with the RAD level of choice. We chose to run RAID level 5.
   While Linux does have built in drivers for the DPT controller card,
   DPT does not offer Linux utilities to configure the unit. What I did
   was temporarily plug a 200 meg IDE hard drive into the server to boot
   from and ran the DOS configuration utilities which are graphical and
   easy to follow. Using the mouse, I selected the three drives that I
   wanted to include in my RAID, then selected the RAID level I wanted,
   saved the configuration and shutdown the computer. I then unplugged
   the IDE DOS drive and reconnected the IDE Linux boot drive.
   
   I kind of cheated when I installed the driver for the SCSI card by
   rerunning the Linux setup program. I had other things that needed
   fixing, so I thought this would be the best way. I could have just
   added the daemon by using the tools in the control panel as well or by
   typing insmod eata-dma at the command prompt and the driver would be
   loaded and I could see the report that the system now recognizes my
   SCSI card and RAID. During the installation, select YES when asked if
   you have a SCSI card and select correct driver (EATA-DMA) for the card
   you have. When you are finished and reboot the computer, you will see
   the RAID initialize and report the settings you configured under DOS,
   then the kernel recognizing the card.
   
   Now, you need to create a partition and format the drive. To make a
   partition, use the fdisk command and follow the menu to make a Linux
   primary partition. Formatting the RAID is as easy as formatting any
   other drive. Remember that the system sees your RAID as a single,
   large disk. To format it in Linux, issue the mkefs2 /dev/sda1, or
   whatever SCSI drive it is. To actually use the disk after formatting,
   you need to mount it someplace. I wanted to use this disk for the home
   directories of our users, so I mounted it as /home/raid. But, whenever
   I added a user, they were still being added to /home and not on the
   RAID, so I edited the /usr/sbin/adduser script (which is just a Perl
   script) and changed the home directory location to /home/raid. Now,
   whenever I add a user, they are added to the RAID.
   
                                                     Daily administration
                                                                         
                                                           System backups
                                                                         
   I have a SCSI Hewlett Packard SureStore 6000 4mm DAT drive that I am
   setting up for backup duties for our Linux server. Currently, I am
   backing up all data through Samba to our Windows NT server using
   
   another SureStore 6000 tape drive and Cheyenne Arcserve software. I
   have also been known to make a quick backup to the RAID using tar. Tar
   is a simple utility that has been around Unix almost as long as Unix
   has been around.
   
   To make a tar backup, just issue the following command:
   
   tar cvf archivename.tar /directory-to-archive
   
   This will create a tar file named archive.tar of the contents of the
   directory directory-to-archive. While this works fine, the resulting
   file might be very large because we did not apply any compression. By
   
   modifying the command to look like this:
   
   tar cvzf archivename.tar.gz /directory-to-archive
   
   We compress the tar file with gzip after the file is made. At a later
   date, we might want to view what is in the tar file, so we can issue
   the tar tvf archivename.tar.gz to list the files in the archive.
   
   While backing up to disk is OK for a temporary thing, you should
   always backup to tape for critical data. Linux supports two types of
   tape drives. The first is the style that connects to the floppy drive
   
   controller, like the Colorado drives and Iomega Ditto. The other style
   connect to a SCSI controller. Floppy tape drives have the device names
   of /dev/ft0, dev/ft1 and so on. SCSI drives are /dev/st0, /dev/st1 and
   so on. These devices are "rewinding" devices which rewind the tape
   when the operation is completed. IF you are archiving more than one
   session to the tape, then use the non-rewinding devices /dev/nft0,
   /dev/nrft1, /dev/nst0, /dev/nst1 and so on.
   
   After writing the archive to tape, you can use the mt (magnetic tape)
   command to rewind, retention and find sessions on tape. The table
   below shows the commands.
   
   mt /dev/nft0 rewind
   
   mt /dev/nft0 retention
   
   mt /dev/nft0 fsf 1 skips the current session to find the next session
   on tape.
   
   To use the mt command, you must use the non-rewinding devices.
   
   Using tar to make backups has its good points and its bad points. On
   the bad side, neither tar or gzip are fault-tolerant. Compressing tar
   files with gzip will greatly reduce the amount of space on the backup
   
   media, but if even one block of the archive gets corrupted, which can
   happen on tapes, the entire file can be useless. Usually, you will be
   able to retrieve all data up to that point, though. A better solution
   is to use a "real" backup system such as BRU (Backup and Restore
   Utility) that comes with a purchased version of RedHat Linux 5.0.
   Backup systems usually compress each file individually, so that if the
   media is damaged, you will not usually lose the entire archive.
   
   BRU has both a command prompt interface and a graphical X-Windows
   interface and is included with RedHat 5.0. BRU offers automated backup
   scheduling and scripting, so it is very easy to setup a simple but
   effective and reliable backup system. I find the system as easy to
   maintain as ArcServe on Windows NT.
   
                                                        Scheduling events
                                                                         
   Linux has a very easy to use scheduler program called cron that will
   run commands, scripts or programs at the scheduled times. To edit the
   list of events, issue the crontab -e command. This will start the
   default editor (usually vi, but I changed mine to joe). When you exit
   the editor, cron will install the new config file you just edited and
   schedule all the jobs. You can view the schedule by issuing the
   crontab -l command:
   
   SHELL=/bin/bash
   PATH=/sbin:/bin:/usr/sbin:/usr/bin
   MAILTO=root
   # Run any at jobs every minute
   # * * * * * root [ -x /usr/sbin/atrun ] && /usr/sbin/atrun
   # run-parts
   # 01 * * * * root run-parts /etc/cron.hourly
   # 02 1 * * * root run-parts /etc/cron.daily
   # 02 2 * * 0 root run-parts /etc/cron.weekly
   # 02 3 1 * * root run-parts /etc/cron.monthly
   # Remove /tmp, /var/tmp files not accessed in 10 days (240 hours)
   # 41 02 * * * root /usr/sbin/tmpwatch 240 /tmp /var/tmp
   # Remove formatted man pages not accessed in 10 days
   # 39 02 * * * root /usr/sbin/tmpwatch 240 /var/catman/cat?
   #############################################################
   # WWW logs. I run 2 so I can compare results.
   #############################################################
   # Run web one web log utility 0 0-23 * * * /usr/bin/log
   02 1 * * * /usr/bin/log
   # Run the other web log utility 0 0-23 * * *
   /usr/local/mkstats/mkstats.pl -c mkstats.config
   02 1 * * * /usr/local/mkstats/mkstats.pl -c mkstats.config
   #############################################################
   #############################################################
   # Live stream management
   #############################################################
   # Create xdm file for live stream for Sports Nightly (5:45 pm)
   45 17 * * 1,2,3,4,5 livestream-on
   # Kill xdm file for live stream for Sports Nightly (8:10 pm)
   10 20 * * 1,2,3,4,5 livestream-off
   # Create xdm file for live stream for Saturday games (7:00 am)
   0 7 * * 6 livestream-on
   # Kill xdm file for live stream for Saturday games (10:00 pm)
   0 22 * * 6 livestream-off
   # Check the 3.0 server to see if it is running and not dead! (every
   minute)
   1-59 * * * * /usr/local/streamworks-3.0/checkSWserver
   ##############################################################
   # Check to see if network volumes are mounted (at 10:00 p.m.).
   # These need to be mounted since this machine performs the
   # backup at 11:55.
   0 22 * * 1,2,3,4,5 checkmounts
   # copy BIP from Intrepid to exeter (WWW)
   0 23 * * 1,2,3,4,5 /usr/local/bin/mvbip
   # backup userdata from intrepid
   55 23 * * 1,2,3,4,5 bu-userdata
   # backup CATS
   55 23 * * 1,2,3,4,5 bu-cats
   # backup Marketing
   0 3 * * 1,2,3,4,5 bu-marketing
   # mail orders to quinn
   0 8 * * 1,2,3,4,5 /usr/local/bin/mailunporders.pl  Each entry has a
   specific configuration to follow. If you want the command to run every
   day at 1:00 AM, specify the minute as 0 and the hour as 1. The other
   three fields should be asterisks, which means ``every day and month at
   the given time.
   
   You might notice the entry
   
   # Check to see if network volumes are mounted (at 10:00 p.m.).
   # These need to be mounted since this machine performs the
   # backup at 11:55.
   0 22 * * 1,2,3,4,5 checkmounts
   
   This calls a script I wrote to check that the NT server is mounted so
   I can backup all data on it. I mount the server using the smbmount
   command which allows a Linux machine to mount shares from a Windows
   machine. This script just verifies that a certain file or directory is
   actually at the mount point. I use these ``reference'' files for
   checking purposes, so they are read-only, so they can't be
   accidentally deleted by users. The script is listed here:
   
   #!/bin/sh
   # Cronjob to remount network drives if they are not mounted.
   # Author: Quinn P. Coldiron
   if [ -z "`ls /mnt/exeter | grep InetPub | grep -v grep`" ]
   then
   umount /mnt/exeter
   /mnt/mountexeter
   echo "Exeter remounted `date`"
   fi
   if [ -z "`ls /mnt/intrepid-f | grep BLINE | grep -v grep`" ]
   then
   umount /mnt/intrepid-f
   /mnt/mountintrepid-f
   echo "Intrepid F remounted `date`"
   fi
   if [ -z "`ls /mnt/intrepid-g | grep QC | grep -v grep`" ]
   then
   umount /mnt/intrepid-g
   /mnt/mountintrepid-g
   echo "Intrepid G remounted `date`"
   fi
   if [ -z "`ls /mnt/intrepid-mrktdept | grep KK | grep -v grep`" ]
   then
   umount /mnt/mountintrepid-mrkt
   /mnt/mountintrepid-mrktdept
   echo "Marketing remounted `date`"
   fi
   echo "All network volumes mounted."
   
   
                                     Replacing your Desktop OS with Linux
                                                                         
   Places to go:
     * RedHat
     * K Desktop
     * Amazing Linux Desktops
       
   I have wanted to make Linux my desktop operating system for a long
   time, but I couldn't because I needed to be able to run the following
   applications: Microsoft Word, WordPerfect, Microsoft Excel, Microsoft
   Access, our internal mail system (Pegasus), Microsoft Access and
   Microsoft Visual Basic. I have recently narrowed the list of required
   applications that do not have a Linux counterpart down to Access and
   Visual Basic, which we will analyze later.
   
   I have found that, for the most part, I can replace Microsoft Office
   with Applixware. Applixware is an office suite for Linux (an many
   other Unix platforms) that can read and write Word and Excel files,
   which allows me to share documents with the rest of the press. While I
   still cannot read Access databases, I am working out a solution for
   that which we will discuss later.
   
   Applix Words
     *  Live links to Applixware or third-party applications
     *  Mail-enabled compound document technology
     *  Landscape, portrait and merge printing
     *  Multiple undo and redo
     *  Hypertext with optional HTML output
     *  Forms editor
     *  International dictionaries, thesauri and spell checkers
     *  Conditional text and cross-referencing; find and replace
     *  Embedded equations and calculation support
     *  Multiple typefaces, type styles and sizes
     *  Highly graphical user interface
     *  Tables and frames; borders and shading
     *  Multimedia support including audio and video
       
   Applix Spreadsheets
     *  Live links to other Applixware and external applications
     *  Calculation-based attributes
     *  3D spreadsheets and charts
     *  Integration of external functions
     *  Built-in string, financial, mathematical, and statistical
       functions
     *  Goal seeking
     *  Multiple named views
     *  Dynamic inter-spreadsheet links
     *  Live graphs and charts
     *  Editable graph styles
     *  Print preview
     *  Borders and shading
     *  Drag-and-drop moving of cells
     *  Projection tables
     *  Relative and absolute cell references
     *  Built-in database functions
     *  Built-in shared library, RPC, and shell command mechanisms
     *  True minimal recalculation
       
   Applix Presentation Graphics
     *  Feature-rich palette, fill patterns & drawing tools
     *  Horizontal and vertical shearing
     *  User-definable fill patterns, brush styles and shapes
     *  Unlimited color support and point sizes
     *  Rotating and scaling options
     *  Drop shadows
     *  Text wrapping
     *  Image digitizing
     *  Pixel editing
     *  Managed layers and animation
       
   Applix Mail
     *  Fully mail-enables all Applixware products
     *  Personal and global user lists, distribution lists and aliases
     *  Sorting, filing and querying on incoming messages
     *  Automatic conversion of messages/documents to recipient's
       preferences
     *  UNIX sendmail transport and MIME compliant
     *  Shared folders
       
   Applix HTML Author
     *  Availability of a wide range of basic and advanced HTML concepts
     *  More than 25 standard HTML styles for headlines, subheads, lists
       and text
     *  Auto-conversion of Applix Words styles to standard HTML styles
     *  Auto-conversion of Applix Graphics and Applix Presents to GIF,
       including linked or embedded graphics
     *  Auto-conversion or creation of tables
     *  Full control over background color, text and hyperlink colors
     *  Auto-bulleting and auto-listing functions
     *  Dialog boxes and pull-down menus for all attributes and
       activities
     *  Straightforward linking and editing of existing GIF files
       
   The Extension Language Facility (ELF) and Macros
     *  Robust interpretive programming language
     *  TCP/IP socket interface and remote procedure calls (RPCs)
     *  Interactive debugger, compiler/interpreter
     *  Arithmetic, string and Boolean operators
     *  Over 2500 built-in macros. Time-saving features for all users
     *  User-definable menu bars, dialog boxes and keybindings, menu-bar
       editor across all Applixware products
     *  Keystroke and mousepick recorder
     *  Live linking and launching of external applications from Applix
       Words,
     *  Spreadsheets, Presents, and Mail.
     *  User-definable ExpressLine icons for automating tasks
     *  Incremental zoom
       
   Changes from Previous Version
   
   This new version features advanced HTML authoring tools for adding
   pages to your website simply and directly. It also has dramatically
   improved filter technology enabling you, for example, to import and
   work on Word or WordPerfect files and export back in those formats. If
   you want the ``real thing'', Corel has version 7.0 of Word Perfect
   available for Linux.
   
   The graphical user interface for Linux (and Unix in general) is X
   Windows. A typical X Windows setup is shown below. This system is
   running the Common Desktop Environment (CDE) window manager. X Windows
   is divided into two subsystems consisting of a server and a client and
   you are free to change either of these as your want. The main reason
   for changing an X server is to gain better speed and better support
   for your video cards and monitors. The main reason for changing window
   managers is to get the look and feel you desire. You can not change
   the server or window manager under any of the Windows products,
   because Microsoft has decided the look and feel you get. The closest
   they get is the Plus! pack and its themes.
   
   Another possibility , which will save money and breath life into your
   old 486's is to install Linux on them and use them as a NC (Network
   Computer). Linux's GUI is X, so it is perfect for an X terminal (with
   either another Linux machine as the server, or any other Unix system)
   and you can run Insignia Solutions Inc.'s Keoke client under Java in
   order to turn your Linux workstation into a thin client that runs
   Windows (virtual NT) applications.
   
   As a rule, Linux performs radically better than Windows 3.1 given the
   same amount of RAM. Linux can run complete with a graphical desktop on
   a 386 with 4MB of RAM, if you're patient. Add Netscape Navigator, and
   you can get away with a 486 and 8MB of RAM. Consider 16MB of RAM a
   performance sweet spot, especially if you use Communicator. Linux also
   has unimposing disk space requirements. The bare-bones Caldera
   graphical client uses about 68MB of disk space. You'll want to install
   a few more packages than that (Netscape, Java, and perhaps a
   friendlier window manager than the default Fvwm), and you'll need at
   least a 32MB swap partition. When you consider all the factors, a
   200MB disk is plenty for most desktops.
   
                                                                         
                                                                         
                                                               Appendix A
                                                                         
                                            RedHat 5.0 Installation Guide
                                                                         
                                                               Appendix B
                                                                         
                                                                    Samba
                                                                         
                                                               Appendix C
                                                                         
                                                            DOSEMU Manual
     _________________________________________________________________
   
                    Copyright  1998, Quinn P. Coldiron
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                               Revisiting VIM
                                      
                                by Andy Kahn
                                      
                              April 29th, 1998
     _________________________________________________________________
   
                                      
                                      
   Vim stands for "VI Improved", and certainly, it a very much improved
   version of the old text editor, vi. It's been a while since the
   gazette had an article on vim (over a year to be exact!), and a lot
   has changed since then, including a major version release. I decided
   to cover some of the new features (as well as some older features)
   that I find extremely useful in vim, but not in vi.
   
  Features
  
   First of all, let me just run down some of the big features of the
   latest version of vim:
   
       Syntax highlighting
     
       Win32 GUI version
     
       BeOS version, including GUI
     
       MacOS GUI version
     
       VMS version
     
       Built-in scripting language
     
       Perl and Python support
     
       Unlimited undo
     
       Multiple windows
     
       ...and a ton of other good stuff
     
  Syntax highlighting
  
   Personally, I found the syntax highlighting to be one of the most
   useful features of vim. Syntax highlighting (or coloring, as some may
   call it), colors text according to their attributes. For editing code,
   this allows you to have different colors for commented text, keywords,
   numbers, etc. You may not think much of it, but believe me, after
   staring at code for long periods of time, all the text on the screen
   starts looking pretty much the same. It certainly helps to have some
   color differentiate between actual code, and comments in the code! A
   picture is worth a thousand words, so here's a screen shot of my vim
   setup editing main.c from the vim source:
   
                                  [INLINE]
                                      
   You may notice the curious string on the very first line of the file:
   "vi:set ts=8 sts=4 sw=4:" This is just a little formatting shortcut.
   If you write code that other people may look at and/or edit, if they
   also use vim, then the code will be properly indented as you intended
   it to be! This is just like the magic strings people use in emacs:
   "-*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4
   -*-" to make indentation look consistent.
   
  Gui versions
  
   As for all the wonderful GUI versions of vim, here's a screenshot I
   found at http://polder.ubc.kun.nl/~rhialto/be/vim-5.0s-screen1.gif
   showing off the BeOS version:
   
                                  [INLINE]
                                      
   Here is a BIG screenshot of the Unix version of vim with four
   different looks (vim in an xterm, vim using Athena, vim using Athena
   with Xaw3d, and vim using Motif (for Linux users, Vim also works with
   Lesstif)). Click on the image for the full size version:
   
                                   [LINK]
                                      
   There are plenty more screenshots here.
   
  Built-in Scripting
  
   The built-in scripting language is a small language (as opposed to
   Perl and Python) that let's you do some simple things in your vim
   startup file (.exrc or rather, .vimrc). For example, the simplest
   thing to do is to check for a version or feature:

    if version >= 500
    "   Switch on syntax highlighting.
        syntax on

        if has("cscope")
            set csexec=/usr/local/bin/cscope
            set csto=0
            set csta=1
            set csverb=0
            cs add cscope.out
            set csverb=1
        else
            map ^] g^]
        endif
    endif

  Visual Text Selecting
  
   A feature which is present even in the previous version of vim that I
   use frequently is its "Visual" capability. By hitting "v" when in
   command mode, you can highly lines and words and then perform just
   about any normal vim operation on the selected text! This includes,
   deleting, copying, pasting, running more ":ex" commands, and my
   favorite, reindenting. For example, let's say I highlighted the
   following code:
   
                                  [INLINE]
                                      
   If I hit ">" (that's the greater-than sign, or Shift-.), the result
   will look like this:
   
                                  [INLINE]
                                      
   Or if I were to hit "<" (the less-than sign, or Shift-,), I get this
   result:
   
                                  [INLINE]
                                      
   If I really wanted to, I could highlight the entire function, and run
   then run it through the "indent" program:
   
                                  Before:
                                      
                                  [INLINE]
                                      
   
   
   After:
   
   [INLINE]
   
                                      
                                      
  C and C++ tags
  
   Another feature programmers will find handy is vim's ability to deal
   with multiple tags. Vim comes with "Exhuberant Ctags", and with it,
   you can store multiple definitions in the same tags file. Once in vim,
   you can do use ":tselect" or ":tjump" on a tag, and vim will present
   to you a list of the multiple tag entries. Just select from the list,
   and vim will take you there as it normally would with a single tag
   entry!
   
  There's More!
  
   Of course, I could go on and on about all the little (as well as big!)
   things that make vim such a great editor.  But I won't bore you with
   the details. :)  You can go read about them yourself on vim's
   homepage: www.vim.org.  There's plenty of new things being worked on
   and added all the time, including more features in the various GUI
   versions (contact me if you are interested in doing a GTK and/or a QT
   version!), ports to other platforms (including the Amiga), and other
   nifty features.
   
   There are certainly a lot of text editors out there, and if you're a
   vi user, you should definitely consider using vim if you aren't doing
   so already!
     _________________________________________________________________
   
   Andy works at Digital Equipment Corporation doing Digital Unix
   filesystems kernel development. He thinks he's just hacking away at
   more and more C code, and in his copious spare time, he hacks on lots
   of other things, including all the trees in his neighborhood. Feel
   free to send him email.
     _________________________________________________________________
   
                        Copyright  1998, Andy Kahn
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
   A Linux Journal Preview: This article will appear in the August issue
   of Linux Journal.
     _________________________________________________________________
   
                       Sun Joins Linux International
                                      
                           By Marjorie Richardson
     _________________________________________________________________
   
   In May, Sun Microsystems joined Linux International. In a year where
   Netscape has released their source and many companies have announced
   that their products will be supporting Linux, I felt Sun's move was an
   interesting enough development to want to know more. Therefore, I did
   a short e-mail interview with Charles Andres, a Group Manager in
   Market Development Engineering at Sun Microsystems. Here's what he
   told me.
   
   Margie:Why has Sun made the decision to join Linux International? 
   
   Charles: Sun Microsystems is responding to renewed interest in running
   Linux on its UltraSPARC products, such as the Ultra 5. SPARC products
   have always been designed to run UNIX extremely well. Linux runs well
   on UltraSPARC platforms.
   
   It is important to note that this move in no way diminishes Sun's
   support for Solaris, a proven reliable scalable operating system. The
   Solaris environment will still be provided with all SPARC systems and
   is considered by us to be the best operating system for enterprise and
   network computing.
   
   Margie: Is Sun planning to have Linux support for all its products? 
   
   Charles: Sun Microsystems is not planning on selling any products that
   are bundled with Linux. Sun bundles Solaris with every workstation and
   server it currently ships. There are also no plans to provide support
   for Linux directly. However, there are a number of Linux vendors that
   support a variety of platforms. We are working to ensure that these
   vendors include UltraSPARC platform support for their Linux products.
   
   Margie: Does this move represent a shift in policy for Sun? Last year,
   we asked for a picture of a SunSPARC workstation to use on our cover,
   and were refused because ``Linux is a competitor.'' (We used a Ross
   SPARCplug instead.) 
   
   Charles: Sun Microsystems has never had an official policy regarding
   Linux up to now. As stated above, Sun Microsystems has gone from
   having no policy regarding Linux, to helping to ensure that Linux runs
   on SPARC by assisting companies who sell supported versions of Linux.
   
   Margie: How does Sun feel about the ``Open Source'' movement?
   (Prominent in the news, because of Netscape source release.) 
   
   Charles: Sun Microsystems has a long tradition of supporting open
   standards, typically through standardized interfaces, many of which
   Sun has invented. Providing source code may be appropriate in some
   specific instances, but typically works well only in situations where
   trademarks associated with the source code are licensed.
   Compatibility, consistency, reliability and upgrades require a
   business model that can finance the effort required to provide them.
   
   Users who want the freedom of Open Source take on the responsibility
   of maintaining their own source code, but cannot guarantee consistent
   results with other variants. This could become a problem for Netscape
   source variants if they are not uniquely identified. This is why we
   feel brand protection through licensing is so important.
   
   Margie: Some people feel that Java should be made Open Source. Any
   chance of that happening? 
   
   Charles: Source for the Java language is available to anyone who signs
   the Java license which is free for non-commercial use. This is done to
   allow Java to run anywhere, and to avoid problems that could occur
   when source is modified to produce variants that are not consistent
   with the Java language specification.
   
   Margie: Anything else you'd like to add? 
   
   Charles: We look forward to working with you and the Linux community
   to promote the advantages of UNIX and Linux on SPARC in the future.
   
   Margie:Thank you for your time.
     _________________________________________________________________
   
                   Copyright  1998, Marjorie Richardson
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                             Tom's 2 cent Tips
                                      
                               By Tom Bryant
     _________________________________________________________________
   
   The notes listed below document the author's "show stoppers" which
   were made as he learned UNIX, after working on DOS, VMS, and other
   systems. There is a small chance that you will make exactly the same
   error, and this document will help you to solve it. What is far more
   likely is that you will skim through it, and hopefully learn one very
   important thing:
   
   Almost all errors are trivial, and result from your understanding a
   Unix function *almost* completely. Gross errors in understanding are
   very rare, although when you hit a show stopper, you usually get the
   initial impression that you are hopelessly in left field and will
   never understand this cryptic operating system. Not True!! *Do not
   give up*!
   
   I suppose that you have already guessed it, but the FAQs, man pages
   and emacs info documentation comes with Linux, and *really* help out.
   You have to really dig: there are bookshelves of documentation in the
   above sources. You will probably learn more about certain topics than
   you wanted to, but after a while all this knowledge begins to look
   good on your resume. While I have tried to avoid overlap in this
   document, some does exist. It should give you pause that there is so
   little overlap! A modern operating system is a complex, many faceted
   beast. Take it a facet at a time and you'll get around it!
   
   UNIX is largely free of the system crashes that plague DOS and the
   MAC. This is because a user account is almost incapable of accessing
   the system resources required to crash the system. When you're running
   in DOS or MAC mode, you (or more often, programs that you run) can
   crash the system. I once complexly wiped my hard disk while running
   Borland's C++ compiler. I have never had this happen with Linux. I've
   never, in five years, crashed the system so badly that I had to reset.
   Granted, some functions (X windows and the modem) required a reset,
   but I could always get to a root virtual terminal to shut down
   gracefully. I've merrily crashed VMS, other Unicies, and of course,
   anything Microsoft has ever produced, from DOS 3.3 to NT. Linux is
   robust.
   
   I suppose no introduction is complete without a testimonial. Here
   goes: I mentioned above that I had worked on a number of systems
   before embracing Unix. Unix (especially Linux) is the best system I
   have *ever* worked on. Give it a chance: it takes a while to collect a
   "critical mass" of Unix commands to make the system really fly, but
   once you do, you'll become one of those insufferable Unix propeller
   heads who claim (truthfully) that nothing else even comes close!
   
   Please Note: The author has made every effort to insure the
   correctness of the information which follows. However, there are NO
   warranties, expressed or implied, for this information. In other
   words, if something goes wrong, it's your problem.
     _________________________________________________________________
   
  Contents:
  
     * adduser
     * ar
     * Backing Up
     * bash
     * C
     * chmod
     * cshrc
     * find
     * ftp
     * gdb
     * imake
     * kermit
     * login
     * less
     * Linux
     * mail
     * make
     * modem
     * Networking
     * nroff
     * qsort
     * PPP
     * rm
     * Setup
     * swapon
     * tar
     * test
     * Time
     * useradd
     * Virtual Terminals
     * X
     _________________________________________________________________
   
   Alphabetical list of utilities with one or more tips with them:
     _________________________________________________________________
   
   adduser
   
   You can only run this from root, but it is an essential command.
   Almost all of your time spent in Linux should be spent in a user
   account of your own creation, as this account is prevented from
   executing disastrous commands such as rm -rf /* (This cleans your disk
   in a disastrously complete fashion.)
   
   MORAL: Always run in a user account, not root unless you are doing
   some system administration which will only work in root.
     _________________________________________________________________
   
   ar
   
   Ar creates a library file, which, after you get a utility program
   you'll be using in other programs, allows you to easily access the
   object files of that program. The files are created by the following
   command:

        ar -r libArchiveName.a objectfile.o

   ArchiveName is, by convention, named libArchiveName.a. However, you
   refer to in your make file only by ArchiveName. e.g

       LIBFILES = ... -lArchiveName ...
     _________________________________________________________________
   
   Backing up.
   
   Having your system crash and not loosing valuable data is what
   separates the computer pros from the also rans. Here's how I do it.
   
   All of the software on my system is safely contained on the CD that I
   used to load it in. There's no reason to back up this stuff. CDs are
   more stable than any tape or disk backup I know of.
   
   I only back up files that I have fiddled with. My programs,
   configuration files, documents, etc. I have a script file, sall (save
   all) which goes to each directory that I have stuff in, tars it, gzips
   it and then saves it to floppy.
   
   This stuff all fits on one 1.44 Mb disk. It represents about 730 pages
   of single spaced typewritten output. That's a lot of typing. Most
   books aren't that big. If you have more stuff than this, I'd suspect
   that 80% of it is stuff you haven't touched in a year. You can back it
   up to a disk, put the disk in a safe place and pretty much forget it.
   Of course, if you gzip the result, you can usually more than triple
   the amount of stuff you back up.
   
   I have 15+ disks which I keep my backups on, and back up at the end of
   any day that I have done a substantial amount of input. This gives me
   access to a month or more of past versions.
   
   You'll find your own way in this. The important thing is to *do* it.
   Then you can feel almost smug when you hard disk finally dies.
     _________________________________________________________________
   
   bash (and ksh and sh)
   
   To set an environmental variable with bash use the following syntax:

    VARIABLE=value

   For example, to tell bash that your are a vt100 type terminal, enter:

         TERM=vt100; export TERM

   NOTE: There are no spaces around the equal sign. This is true for all
   bash commands, not just setting environmental variables. Remember this
   and be saved frustration down the road.
     _________________________________________________________________
   
   C
    1. As Unix is currently configured, there is no easy way to get a
       single keystroke without using curses or changing the terminal
       characteristics. Your users will just have to get used to hitting
       Enter after an input. If they can't, uses curses or the GCC C
       manual (actually a superb reference for C libraries well worth the
       $50+ bucks!)
    2. After you have output to an opened text file, it is a good idea to
       send a fflush(stdout) command. This will flush the buffer and keep
       you from overflowing it if you get over 2048 characters in it,
       which is easy to do.
    3. To use math.h functions in a c program:
       Link in the math libraries by typing:

        gcc source.cxx -lm
   Math libraries MUST be linked in last!!! Old UNIX linker convention!
    4. When declaring pointers, every variable must be proceeded by an
       asterisk!

       int *v1,
            v2,
            v3;
   Results in compiler complaints of bad unary operator arguments!
       Correct:

       int *v1,
           *v2,
           *v3;
    5. To capture the output of a compile which is causing problems, and
       outputting reams of digital vomit, use this construct from a sh
       based shell like bash:

       gcc -c flaw.cxx &> TextCapture
   or

       gcc -c flaw.cxx 2> TextCapture
   The errors will be captured in TextCapture.
    6. A static variable is initialized only once in a function. All
       other calls to that function result in the existing value of the
       variable being used.
    7. Shifts in most Unix C compliers are actually integer divides and
       multiplies by 2. Never mind what the ANSI spec says:
       This code gives problems:

       long n = 0x80000000;
       for (i = 0; i < 24; i++) printf("\n n is now %lx.", n >> i);
   n must be declared as an unsigned long for this to produce reasonable
       results. The fact that n starts negative fowls the compiler up.
       This also indicates that right and left shifts are implemented as
       divide and multiply by 2 with the GNU C++ compiler.
    8. This is perhaps my favorite subtle error. If I only had a dollar
       for every hour I've spent searching for this self imposed
       klutziness...

    for (i = 0; i < upper_limit; i++);
    {
        this = cant_happen;
        the_loop = wont_execute;
    }
   See the semi-colon at the end of the for statement line? The program
       pauses for an empty loop of upper_limit cycles, and then proceeds
       to do just the first installment of the loop and nothing else.
       It's quite easy to to, too, even after you've been bitten a few
       times by it.
    9. You can core dump a program sooner than quicker by writing too
       much stuff into a string, so that it doesn't end with that all
       important 0. e.g.:

       double age;
       char oops[52];
       int len; ...
       sprintf(oops,"The age of the universe in nanoseconds is %f.\n",age);
       len = strlen(oops);
   The fragment will die at the strlen call, as the string is longer than
       50 characters, even if it is 10 character in the sprintf
       statement. The age of the universe in nanoseconds is about 19
       characters long.
   10. This code will pass a file pointer (tfile) to a function:

    #include <stdio.h>  /* fclose, fopen, printf.*/
    #include <stdlib.h> /* exit.                 */

    void main(int argc, char* argv[])
    {
        /* Function Prototypes:*/

        int openfile(FILE** tfile);

        /* Variables:*/

        FILE *tfile;       /* Test file.*/

        /* Begin:*/

        printf("Starting program.  tfile = %p.\n", tfile);
        openfile(&tfile);
        printf("Back in main.  tfile = %p\n", tfile);
        fclose(tfile);
    }

    /* Open the file and return the pointer.*/

    int openfile(FILE **tfile)
    {
        *tfile = fopen("junk","wb");
        printf("Tfile just opened.  tfile = %p, *tfile = %p.\n",
                tfile, *tfile);
        return 1;
    }
   11. This code will allow you to reference an array of characters as an
       array of longs without using a union:

    int bozo(void)
    {
        void use_long(long *array); // Function prototype.
        char *array;                // The character array.

        use_long((long*) array);
    }

    void use_long(long *array);
    {
        // Reference the array as longs here.
    }
   12. Profiling:
       Compile with the flag -pg (for gprof compatible output). Link with
       the -pg flag AT THE END OF THE LINK LIST. e.g:

    gcc  -o run_time_image my_main.o my_other_stuff.o -pg

   Even then, don't expect miracles. This does not work on an mpeg2
       package I found on the net.
   13. Reading in a globbed (wildcarded) file list:
       If you want you program to work on all files in a directory, you
       can enter "myprog *". Argc will count the number of files out
       there, and argv will be the char **list of their names.
   14. The code

        string1[i++] = string2[i];
   Will take the nth component of string2 and put it the into the nth
       component of string1, then increment i. This is how GCC and the
       SGI C compiler do it.
       The Motorola C compiler takes the (n + 1)th component of string2
       and puts it into the nth component of string1. I gets incremented
       *before* the assignment. Safer is to just use this code:

        string1[i] = string2[i];
        i++;
   15. The code

    if (index++ == NR_PTS) index = 0; // Fails to implement a circular buffer.
   Does not implement the desired buffer. Let's say that NR_PTS is 100,
       and index is 99. The comparison is made when index is 99. Index is
       not reset, by then it is set to 100 by the ++. Next time, of
       course, the index will be reset to 0, but by then, it's
       overwritten whatever was in buffer[100], which is the 101st entry
       in buffer, a 100 int (or whatever) array.
       use this instead:

    if (++index == NR_PTS) index = 0; // Implements the circular buffer.
   16. Occasionally, if you allocate a *huge* array (I needed one 10.7 MB
       to make this one happen) the program will bomb as it tries to pass
       the array to another function. For example:

        char moby[20000000];  // A really big text file.
   There simply wasn't enough room on the C/C++ stack to hold the array,
       and the program bombed as soon as it tried to access it. The
       compiler, of course, didn't complain.
       The fix is to malloc (or new, in C++) the array:

        char *moby;  // A really big text file.

    moby = (char*) malloc(20000000);
    if (moby == NULL)
    {
        printf("Hey! I'm not big enough to hold moby!\n");
    }
   17. When it works on one machine and not on others, or in the debugger
       and not out of it:
       You might well be not initializing your variables properly.
       Sometimes one machine will just happen to initialize a variable to
       a non lethal value, and the others won't. See inexplicable errors
       item 3 as well.
   18. Inexplicable errors:
       Occasionally, you will face very odd errors. A function works
       perfectly *most* of the time. The rest of the time, it has very
       strange errors. Variables seem to change value in a capricious
       way, and your frustration index soars off of the charts. If you're
       a beginner, you decide that programming is beyond you, and give
       up. Don't despair, quite yet. There are a few tricks, not written
       in any book that I have seen, that I have developed over the years
       to help you over these rough spots. In general, try these in the
       order given.
         1. Rewrite your code until it is remorselessly neat.
         2. Step through it line by line with a good debugger (I
            recommend GNU's GDB for C code. It's a bit flaky (1998) for
            C++).
         3. If these steps did not fix the problem, try recompiling
            everything with a command like:

                    rm *.o     // Important!
                    make       // Or whatever compilation command you use.
         4. If you have inconsistent program results, so that the program
            works most of the time, and inexplicably fails occasionally,
            carefully check to see that all of your variables have been
            initialized properly.
         5. Sometimes the memory can be corrupted by new routines not
            fitting into word boundaries on your machine. Granted, this
            is *not* supposed to happen, but it does anyway, even in the
            best compilers and linkers. Try declaring arrays to be 1
            index larger than they should be and see if that fixes it.
            (This is getting to be a rare C error (1998)).
              1. There are times when the program does not misbehave in
                 the debugger, and if you put a few diagnostic printfs in
                 it to further check it out, it still does not die. These
                 temporary measures may need to be made permanent as the
                 extra variables you created to let you see what is going
                 on have pushed the memory usage boundaries of the
                 function to a more robust spot (i.e. to a word
                 boundary).
         6. Once you think you've fixed the problem, *TEST EVERYTHING*
            before you release anything.
         7. Keep at it. With practice, you can dumb yourself down to the
            intelligence level of a compiler. Good Luck!
     _________________________________________________________________
   
   chmod
   
   The command chmod XXX .* can have unforeseen after effects. It affects
   the directory you're in as well as the files in that directory! You
   might find that only root can access the files, and then only after
   chmoding them back to where they were supposed to be.
   
   cpio (not often used, most Unix users use tar instead)
   
   To use cpio, for backups, specify:

    find (path name) [-name] | cpio -oc > (destination file and directory.)

   To extract a cpio file:

    cpio -i [-F (full file specification)] [-r rename files]
     _________________________________________________________________
   
   cshrc
   
   To change the erase key from ctrl h to stty erase \x7F To the .cshrc
   file. Unfortunately, the C shell interpreter does not understand the
   sequence \x7F, and I needed to write a short C program to insert the
   byte with value 127 (7F hex) at the end of the file.
   
   To set the terminal from 'console' or 'Linux' to vt100 (needed by elm
   (a mail handling utility)) on an SGI, put this line in your .cshrc
   file in you SGI home directory:

        eval `tset -s -Q vt100`

   If your etc/ttytype file is set up to recognize vt100s, this should
   work.
   
   Note this does not work on all machines. These methods were useless on
   a motorola, for example
     _________________________________________________________________
   
   find 

    find (path name) -name (file name) -print

   wildcards at the beginning of a find names must be preceded by a \.
   e.g.:

        find / -name "\*bozo*" -print

   finds all files with the letters bozo in them. Some systems require
   the quotes as well.
     _________________________________________________________________
   
   ftp
   
   Make sure the line setting is binary. Zipped files will not transfer
   correctly if this is not set.
     _________________________________________________________________
   
   gdb (and dbx)
   
   To examine a core file:

        gdb <executable file name> <core file name>

   The core file name is usually "core".
   
   To examine an array:

        p *arrayName@number_of_bytes_you_want_to_see
     _________________________________________________________________
   
   imake
   
   The new way of handling compiling and linking programs is with a
   utility called imake. It makes programs easier to move around from
   machine to machine. To use it:
    1. Read the imake, make and xmkmf man pages. Also any README files
       that came with the program you're trying to build. If you're going
       to be getting into some serious program development, the emacs
       info page on make is a must read.
    2. Back up everything! Source, Makefile, imakefile, etc.
    3. imake
    4. If imake doesn't work, try xmkmf
    5. If it *still* doesn't work, go back to step 0.
     _________________________________________________________________
   
   kermit (quick check of file integrity)
   
   This is true for any other data transfer protocol as well, such as
   ftp.
   
   Check the size of the files that you have transfered to the target
   system. If they are not the same size, something went wrong.
     _________________________________________________________________
   
   login
   
   To disable the annoying wait after an unsuccessful login, edit the
   file /etc/login.defs. Change the parameter FAIL_DELAY from whatever
   it's set to to 0. You'll have to be root to do this.

link (ln)


   to create a symbolic link:

        ln -s <existing file or directory> <Linked file or directory$gt;

   e.g.:

        ln -s OldFile NewLink


   This creates a symbolic link name NewLink that points to OldFile. When
   you access NewLink, Unix actually accesses OldFile.
   
   Links are mainly used to save disk space, allowing yu to have the same
   file in several different places without actually having maintain
   multiple copies of the file.
     _________________________________________________________________
   
   less
   
   Less can't display ANSI color escape sequences like most of the other
   Unix text output utilities can. It instead tries to print them with
   ugly results. On other unicies, the work around is to use the pg
   function, but it's not avalible on Linux (yet).
     _________________________________________________________________
   
   Linux
   
   To regain text that has scrolled off of the screen, try shift-PageUp
   and/or shift-PageDown. This will work on a given console until you
   shift to another one. When you shift back, however, you will find that
   the scrolled text has been lost.
   
   To change from virtual console to virtual console, use left alt (only
   the left alt key works on my machine) FX where FX is one of the
   function keys F1 thru F6. F7 will be your X window, and isn't set up
   for you to log into it, but see the note below.
   
   When you are in X, you can move back to the text consoles by
   simultaneously typing the control and alt keys, and then the function
   key of the virtual console you want to be in.
   
   To add more virtual consoles edit your /etc/ inittab file and add a
   line to the getty configuration section. I added this line to inittab
   and it allowed me to add another virtual console:

c7:456:respawn:/sbin/agetty 38400 tty7

   This let me log into F7, but not as root. To log in as root, I added
   this line to the /etc/securetty file:

    tty7

   I did not add further consoles, as 7 is the canonical number for the
   maximum number of things you want to juggle at one time, and each
   virtual console takes up precious RAM even if it is dormant.
   
   When your screen gives weird output for lower case letters, try this:

      echo "^V^[c"

   (that's E C H O space control-V escape C return) to fix it.
     _________________________________________________________________
   
   mail
   
   To send a message with a subject:

    mail -s "This is the subject" recipient@computer.full.ip.address < message

   To forward your mail:
   
   Create a file in your root directory called .forward. This file should
   contain the address of the machine that you want to send the mail to:
   
   e.g. My .forward file reads:

        Thomas.V.Bryant.1@gsfc.nasa.gov
     _________________________________________________________________
   
   make
   
   The make utility *requires* that commands (as listed under a
   target:dependency line) begin with a tab (ASCII 09).
   
   If your emacs tab stops are set to under 8, emacs will insert spaces
   (ASCII 32), and not a tab. This will stop make dead in its tracks.
   You'll have to reset your tabs to edit a makefile.
   
   If you break up the lines in your make file (a good idea: readability
   is king!) don't put anything after your backslash (line continuation
   symbol) or make will throw up on it:

       LIBS = Lmylib Lyourlib ... \
                                   ^
                                   |
                                   |
                     No spaces or tabs or anything after here!!!
     _________________________________________________________________
   
   modem
   
   When you install linux, your serial ports will not be configured. You
   have to enable the call to /etc/rc.d/rc.serial in /etc/rc/rc.S:

    # Run serial port setup script:
    # (CAREFUL! This can make some systems hang if the rc.serial script isn't
    # set up correctly.  If this happens, you may have to edit the file from a
    # boot disk)
    #
    # You need to enable this line (remove the # comment symbol):

    . /etc/rc.d/rc.serial

    #  for your modem to work.
     _________________________________________________________________
   
   Networking
   
   Installation (for Author's PPP link -- a *very* brief reminder list):

    Load the networking module in the slakware file.
    Create or copy the /etc/hosts file.
    Create or copy the /etc/resolve.conf.
    Edit /etc/rc.d/rc.serial.


   Run time problems:
   
   Try the ifconfig and netstat commands to find out what your current
   network configuration is.
   
   Use the ping command to check you connections.
   
   Make sure that your linux kernel has drivers both for your network
   card and ethernet. Networking will not work without them.
     _________________________________________________________________
   
   nroff
   
   Many text files are quasi-readable, and filled with control
   characters. If the file turns out to be an nroff man page, you can
   read it with the command:

        groff -Tascii -man file.name | less

   Often a variation of this command is necessary. See the man pages for
   groff and grog. Grog tries to look at the file for you and suggest a
   command. This is one that repays a lot of fiddling. Back up the
   original file, and groff away. Usually you'll get it. Remember also
   that postscript files (usually denoted by a .ps suffix) are read with
   the ghostscript command from X.
     _________________________________________________________________
   
   qsort
   
   Here's a wierd one. The qsort function has a hard time calling it's
   comparison function from a C file compiled with gcc. It works fine if
   gcc thinks it's compiling a C++ file. Here's a pixel value sort I did,
   heavily edited:

        int pixCmp(pixel*, pixel*); // Return -1, 0, or 1. For the qsort call.
        ...
        qsort(data, BigNumber, sizeof(pixel), pixCmp);
        ...
        int pixCmp(pixel* a,
                   pixel* b)
        {
            if (a->clr > b->clr) return 1;
            else if (a->clr < b->clr) return -1;
            else return 0;
        }

   If the file is named pixels.c, it produces the following gcc error:

            pixels.c: In function `readData':
            pixels.c:164: warning: passing arg 4 of `qsort' from incompatible
                                   pointer type

   If the file is named pixels.C, it produces no errors:
     _________________________________________________________________
   
   PPP
   
   Installing PPP to work with Linux can be done, but it is not trivial.
   
   I'll describe the steps that worked for me, so that you might get a
   variation on them to work for you.
   
   Don't expect it to work perfectly the first time. You'll have to futz
   with it, unless you are very lucky.
   
   PPP must first be installed in your kernel. To check if it is there:

        dmesg | grep -i ppp

   You should get something that looks like this:

        PPP: version 0.2.7 (4 channels) NEW_TTY_DRIVERS OPTIMIZE_FLAGS
        PPP line discipline registered.

   If you don't, you'll have to recompile your kernel, or get a copy of a
   kernel that has ppp on it from the net. Instructions for doing this
   are found in the file /usr/doc/ppp/README.linux.gz. This is where it
   is in my Slackware release, yours will probably be similar. You need
   to read this file now. Before you go any further. Otherwise, what
   follows will read like gibberish.
   
   Read the Readme? Good. Here's how my pppd/chat command looks:

    /usr/sbin/pppd connect '/usr/sbin/chat "" ATDT7035551212 CONNECT "" ogin:\
    tbryant word: secret_password' /dev/modem 38400 -detach crtscts modem    \
    defaultroute noipdefault

   Fill in your appropriate telephone number, user ID and password.
   
   Run the script from your root directory,unless you have given pppd
   suid privileges (recommended).
   
   When I am running the script, I do so from an X windows term, so I can
   start netscape (or whatever X application I want) easily.
   
   Once I've established the connection, then I can run netscape, ftp, or
   telent to other internet connected machines.
   
   My ISP (Internet Service Provider) assigns me a different IP address
   each time I log on. This IP address can be found with ifconfig, or
   from the /var/log/messages file.
   
   The last few lines have what you need:

        Aug 28 20:01:23 3C273 pppd[168]: local IP address 205.252.11.62


   To log off, the PPP-HOWTO.gz document has the following logoff script:

    #!/bin/sh
    DEVICE=ppp0
    #
    # If the ppp0 pid file is present then the program is running.  Stop it.
    if [ -r /var/run/$DEVICE.pid ]; then
            kill -INT `cat /var/run/$DEVICE.pid`
    #
    # If the kill did not work then there is no process running for this
    # pid.  It may also mean that the lock file will be left.  You may wish
    # to delete the lock file at the same time.
          if [ ! "$?" = "0" ]; then
                  rm -f /var/run/$DEVICE.pid
                  echo "ERROR: Removed stale pid file"
                  exit 1
          fi
    #
    # Success.  Let pppd clean up its own junk.
          echo "PPP link to $DEVICE terminated."
          exit 0
    fi
    #
    # The PPP process is not running for ppp0
    echo "ERROR: PPP link is not active on $DEVICE"
    exit 1

   Additional hints not in the README.linux file:
   
   All exchanges between you and you host computer will be logged in the
   /var/log/messages file. Deducing what's going wrong is much easier if
   you just look at the end of this file:

            tail /var/log/messages

   Keep trying, don't be afraid to futz around. If you're well backed up
   (you *ARE*, aren't you?) you won't hurt any of you hardware, or
   permanently damage any software (even this is very unlikely). Good
   Luck!
     _________________________________________________________________
   
   rm
   
   When a file absolutely refuses to go away, try surrounding its name
   with quotes. This might kill it. I needed to remove a file called
   #filename#. Here's how I fared.

      rm #filename#    Refused to work.
      rm "#filename#"  Worked.
      rm '#filename#'  Worked.
      rm \#filename#   Worked.

   The top command worked on the older versions of Linux and SGI's IRIX.
   This is probably a Posix compatibility problem that caused the more
   recent versions of Linux to stop working.
     _________________________________________________________________
   
   Setup
   
   The setup script will not run unless you are in /usr/lib/setup, and
   running as root. Be careful. Back up everything before you start
   playing around with this. Don't be afraid to play, however, as you can
   always improve on the defaults Linux comes with.
     _________________________________________________________________
   
   swapon
   
   To set up a swap file, (needed for installation)
    1. Start you new Linux box with the boot and root disks.
    2. make a partition (The rule of thumb is 1 - 2 times the size of the
       RAM on your machine.) using fdisk. Be sure and set the data type
       to Linux swap.
    3. Format the partition: mkswap -c </dev/partitionName>
    4. Enable swapping in /etc/rc.d/rc.S: /sbin/swapon -a
     _________________________________________________________________
   
   tar
   
   To make a tar file:

       tar -cf tarfilename filename (or directory.  Directory is recursive)

   This creates the file.

       tar -rf tarfilename filename (or directory.  Directory is recursive)

   This appends to an existing file.
   
   To extract a tar file:
   Get into the directory where you want to have the files.

       tar -xf (Complete filespec of the tar file to be extracted.)
     _________________________________________________________________
   
   test
   
   *NEVER* *NEVER* *NEVER* name an executable test. This is a very easy,
   logical thing to do. When you try and run it, the shell will invoke
   it's test utility, find nothing there, and exit silently, leaving you
   very puzzled.
     _________________________________________________________________
   
   Time
   
   To set the system clock (CMOS) from Linux:
   
   Set the system time from the CMOS clock, adjusting the time to correct
   for systematic error, and writ- ting it back into the CMOS clock.
   
   This option uses the file /etc/adjtime to determine how the clock
   changes. It contains three numbers: The first number is the correction
   in seconds per day (for example, if your clock runs 5 seconds fast
   each day, the first number should read -5.0).
   
   The second number tells when clock was last used, in seconds since
   1/1/1970.
   
   The third number is the remaining part of a second that was left over
   after the last adjustment.
   
   The following instructions are from the source code:
    1. create a file /etc/adjtime containing as the first and only line:
       '0.0 0 0.0'
    2. run clock -au or clock -a, depending on whether your CMOS is in
       Universal or Local Time. This updates the second number.
    3. set your system time using the date command. mmddhhmm[yy][.ss]
    4. update your CMOS time using clock -wu (for UT) or clock -w.
    5. replace the first number in /etc/adjtime by your correction.
    6. put the command clock -au or clock -a in your /etc/rc.local, or
       let cron(8) start it regularly.
     _________________________________________________________________
   
   useradd
   
   When a user is added, you have to make sure that the user owns, or at
   least has read, write, and execute privileges on his/her home
   directory. If you neglect this step, the new user will be unable to
   function properly, and perhaps will not be able to log on!
   
   The /usr/bin directory must have its privileges set to 755 in order
   for users to be able to execute the UNIX commands contained therein.
     _________________________________________________________________
   
   Virtual Terminals:
   
   To change from terminal to terminal:

                                Left Alt + fn

   (n is the terminal number, from 1 - 6 and f is a function key.)
   
   To return to virtual terminal text mode from X:

                           Left Alt + Control + fn

   n is again the number of the terminal you want.
   
   To see text that has scrolled off of the screen:

                        Shift + Page up or Page down.

   Moves you up and down by half a screen each time.
   
   To see task information:

 + Scroll Lock


   To see memory information:

                             Shift + Scroll Lock
     _________________________________________________________________
   
   X:
   
   There are few short X tips. You need to read much of the documentation
   that is out there, and but the O'Rielly series in X and Motif if you
   intend to do serious developemt. It's an extrodinary, platform
   independent, system that solves some very difficult problems with
   accessing system resources in a uniform way. It's also very complex,
   with all sorts of redundant functions and kludges. Good Luck.
   
   If you're going to just start getting into building user interfaces, I
   suggest that you bypass X entirely, and concentrate on Java. Of
   course, Java for Unix platforms is based on X, but you shouldn't have
   to worry about that.
     _________________________________________________________________
   
                        Copyright  1998, Tom Bryant
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
   A Linux Journal Preview: This article will appear in the August issue
   of Linux Journal.
     _________________________________________________________________
   
                            UniForum '98 Report
                                      
                               By Phil Hughes
     _________________________________________________________________
   
   I am writing this article as I fly back from the UniForum Association
   Spring '98 Conference. This was the first ever East Coast conference
   held by UniForum in its 17 year history. It was held in Ocean City,
   Maryland--a beautiful town by the Atlantic Ocean.
   
   UniForum is an advocacy organization that promotes the use of Open
   Computing solutions--or, to put it in succinct terms--the use of UNIX
   and UNIX-like solutions. UniForum and Usenix have tended to complement
   each other with UniForum being the conference for suits and Usenix the
   conference for T-shirts.
   
   The conference was a two and a half day event that looked light on
   paper. Once there, I discovered there was too much to do in such a
   short time. For the first two days, there were three tracks: New Open
   Software Development Model and Linux, Network Computing and Best of
   SCO Forum. All tracks included common Plenary and Keynote sessions. On
   the third day there were two three-hour sessions: one presented by the
   Open Group and the other by Linux International. I attended all the
   Linux track sessions as well as the common sessions.
   
   Monday's Plenary session was Eric Raymond's presentation of his paper
   The Cathedral and the Bazaar which is credited with convincing
   Netscape to take their Open Source stance. If you haven't heard the
   talk or read the paper, it is available on our Linux Resources page.
   
   After Jon Hall introduced the Linux track, Frank Hecker, who is a
   systems engineer at Netscape, gave a talk entitled The Why and the How
   that filled in the background of Netscape's decision to embrace the
   Open Source model. For those of us who have been involved in what I
   call ``revolution from below''--that is, attempting to sell Linux or
   Open Source to those in the trenches and let it move up the corporate
   ladder--Frank had some interesting things to say. He said the
   engineers didn't believe Open Source could happen with Netscape. So,
   Frank went to Marc Andreessen with the idea, and the rest is history.
   
   After Frank's talk, we got together for the keynote lunch where Ralph
   Nader (UniForum Press Release) spoke on the Microsoft monopoly and how
   Linux could be a big player in an alternate solution. It was a treat
   to get to meet Ralph and to hear the word Linux come out of his mouth
   just a few days after hearing Marc Andreessen saying it. I brought up
   how U.S. government procurements used to require a POSIX-compliant
   operating system be made available with any system they purchased, and
   Ralph and his staffers are going to look into why that requirement was
   dropped. I asked him to keep LJ up to date on any findings, but you
   might also wish to check out his web site at
   http://www.essential.org/.
   
   Two afternoon sessions were held in the Linux track. The first was
   presented by Ron Workman of Cygnus Solutions, and the second was
   presented by me. Covering mine is easy--I went through a series of
   articles which have appeared in our Linux Means Business column,
   illustrating how companies identified a problem, then used Linux to
   address that problem.
   
   Ron's talk addressed Open Source software from a different direction:
   how a company can succeed in the business of supporting freely
   available software. Cygnus was founded in 1989 to provide commercial
   support for open Internet technologies and has grown to 160 employees.
   The company has succeeded by offering consulting and support on such
   products as the Free Software Foundation's GNU C Compiler.
   
   Monday evening was filled with good food and bad beer (Coors
   Light?--lucky Linus wasn't there) at a beach party hosted by Red Hat
   Software. Like most parties at these conferences, the evening was
   filled with meeting others and talking about computers, the UNIX
   market and telling Microsoft jokes. I found it a valuable time to get
   to know people better, for example, Morgan Von Essen and Garry Paxinos
   of Metro Link, and to thank Alan Fedder and Kathy Goetz of UniForum
   for organizing the conference.
   
   Tuesday morning started with a Plenary by Eid Eid, President of Corel
   Computer (see LJ, Issue 48). If I had to choose one person who
   provided me with the most new information, I would choose Eid. I did
   cheat a little however, as I also talked to him extensively over
   lunch.
   
   Eid's Plenary was a pleasant combination of future fantasy and a look
   at what is available today. The fantasy part consisted of describing a
   day in the life of Mr. Twenty O'One, illustrating what we should
   expect in the near future (2001 isn't that far away) from our personal
   communicator: voice- and e-mail access, voice commands and an
   interface to the Corel NetWinder.
   
   At the office, Mr. Twenty O'One will have a typical Intel-based PC but
   most of his work will be done on his personal communicator and his
   NetWinder. The NetWinder is much faster for doing common tasks
   because, while it is a complete Linux system, common tasks (everything
   from e-mail to video conferencing and replying to e-mail with a voice
   message automatically appended to e-mail) are trivial to access.
   
   After this fictional introduction, Eid went on to cover the pieces
   which actually exist today, including the NetWinder, video
   conferencing, XML and capable portable systems. He went on to say that
   we need to make all the interfaces and standards open so any vendor
   can produce pieces which interoperate. I expect some people were
   surprised when he said, ``Corel, Lotus and others will have no choice
   but to provide some source code for commercial products in the near
   future.''
   
   Eid also pointed out that Microsoft controls over 50% of the money
   made on PC applications. Eid was the Chief Technical Officer for Corel
   Corporation, makers of CorelDraw and owner of Corel Computer before
   coming President of Corel Computer. He explained how Corel had been a
   Microsoft partner until Corel acquired WordPerfect, then Microsoft
   started hiding technology from them.
   
   As many of us have concluded in the past, Eid believes you cannot
   successfully fight Microsoft, but went on to point out what you can
   do. He sees the network computer as the new wave, being less costly
   and more maintainable. The network computer opens up a new market and,
   done right, it can become a market as large as today's personal
   computer market.
   
   The morning session in the Linux Track included a presentation by Don
   Rosenberg of Stromian Technologies on making money with Open Source as
   an OEM/VAR. Differing from Ron Workman's presentation of the previous
   day, Don's presentation was a mini-tutorial on how to get into a
   market and how to make the right distribution choices along the way.
   
   Next, Morgan Von Essen, President of Metro Link, with the help of
   Garry Paxinos, Vice President, presented a talk on Metro Link's
   cooperative work with the XFree86 community--another model of a
   commercial enterprise working with the free software community. In
   this case, they developed technology needed for their commercial
   customers and then gave that technology back to the XFree86 community.
   Doing this makes it easier for Metro Link to continue development,
   because their work becomes standard in new XFree86 releases.
   
   Tuesday's keynote lunch was presented by Janpieter Scheerer who was
   President of Sunsoft and has now moved to head the storage division of
   Sun. He talked about WebTone and made some very interesting points
   demonstrating how the non-Microsoft community is growing faster than
   the Microsoft community. His pointed out that while MS Windows sales
   are growing at 13% a year, companies like Cisco are growing at 30%,
   and that while there are over 100,000,000 MS/PC users, that number is
   a small minority of the six billion people on the planet. He also
   pointed out that every Quicken user who registers their product is a
   UNIX user since the Quicken on-line registration server runs on Sun
   systems.
   
   Janpieter explained that today most ISVs will port their product to
   either NT or Solaris. By mentioning an old Dutch saying, ``the enemy
   of my enemy is my friend,'' he clearly sees Linux as an ally. By the
   same reasoning, we need to see Sun ports as potential Linux ports of
   the future.
   
   Janpieter, like Eid, pointed out that the network computer is in--all
   we need is a $150 device to connect to the Internet. He then went on
   to talk about two subjects: first ``OPEN-standardization'' and then
   Java. This got a reaction from both Eric Raymond and Eid Eid, who both
   pointed out that for Java to be the answer, its standard needs to be
   open. There was no resolution, but I am sure we were heard.
   
   The afternoon Linux track brought Bob Young discussing the size of the
   Linux market or, more accurately, explaining how hard it is to come up
   with an accurate estimate. Bob also announced the availability of the
   Extreme Linux CD which includes all the Beowulf RPMs for those of you
   who want to build your own supercomputer. Jon Hall of Linux
   International closed the track with some general comments and
   preparation work for the workshop the following morning.
   
   On Wednesday the Linux track attendees changed their plans and
   attended the first hour of a presentation entitled What Exciting
   Technology is Emerging? by The Open Group, the organization that owns
   the UNIX brand and standards. In this presentation, the Open Group
   announced the UNIX'98 standard.
   
   Historically, vendors such as Digital, Hewlett-Packard and Sun have
   paid a lot of money to use the UNIX brand. This money goes to support
   The Open Group's work on the standards and enforcement of the
   trademark. While it would be great for Linux or a Linux distribution
   to be UNIX branded, the cost is prohibitive.
   
   The Open Group has now recognized the advantage of getting the Linux
   community on board. While Sun and others anchor the high end of the
   Open Systems community, having an entry-level system compatible with
   the standard would be a plus. This is not yet a done deal. While the
   use of the UNIX trademark is limited to those who have paid the fees,
   the opportunity will be present for a system to be conformant with the
   standard. Stay tuned, this could be the in necessary to tighten the
   bond between Linux and the rest of the UNIX community.
   
   For more information on the UNIX'98 standard, see the web page
   http://www.opengroup.org/.
   
   The melding of minds with regard to UNIX standards, Open Computing and
   Open Source software needs a venue and UniForum has elected to be that
   venue. Here's what Alan Fedder (UniForum Press Release), President of
   UniForum had to say about it:
   
     UniForum Association is the only forum for open discussion and open
     debate about open computing. Where else could Eric Raymond and Mike
     Lambert [of The Open Group] debate each other, listen to each
     other, and have a better understanding of each other's position?
     Where else could you hear Ralph Nader, Eid Eid, Janpieter Scheerer,
     Eric Raymond--all quoting Eric Raymond? Momentous things happened
     at the UniForum Spring Conference in Ocean City--and I honestly
     believe that five years from now, 5,000 people will be telling each
     other they were there when UNIX was saved.
     
   In conclusion, I found attending the conference to be truly worthwhile
   and look forward to going again next year.
     _________________________________________________________________
   
                       Copyright  1998, Phil Hughes
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
    "Linux Gazette...making Linux just a little more fun!"
     _________________________________________________________________
   
                          Using rdist for Backups
                                      
                                By John Pate
     _________________________________________________________________
   
   In Linux Gazette Issue number 24 Gerd Bavendiek described his script
   which he calls "mirror." In this script he makes use of the utility
   'rdist' which is widely available on Unix systems. In my article I
   shall explain how I use 'rdist' which I hope will give the beginning
   Linux user a background to Gerd's article and show how useful 'rdist'
   is to those with multiple computers (which should be every Linux user
   nowadays!)
   
   In the UK today you can get a complete 486DX66 system including
   monitor for a hundred pounds, which has got to be a bargain and ideal
   as a backup system for your "main" computer. Even if you feel its hard
   disk is too small (typically they have them in the 200-300meg range)
   today you can get a 2gig hard disk for under one hundred pounds or an
   850meg one for sixty pounds. So for no more than a couple of a hundred
   pounds you not only have a backup device but a working computer you
   can use in emergency in the event of the failure of your "main"
   machine. I have two 486DX66s, both other peoples' discards which cost
   me nothing apart from extra RAM and a bigger hard disk for the "main"
   machine (and a modem of course - though now I have a couple of spare
   V32bis other people have junked, isn't progress wonderful). One has
   40meg of RAM and is my "main" computer running Slackware 3.3. The
   other has 8meg of RAM and Slackware 3.3 again. The "backup" has a half
   gig hard disk given to me because it makes an unpleasant whine during
   operation. In spite of the noise, the disk works fine so is good for
   backup space. A couple of discarded network cards from a "parts bin"
   and a look at the NET-3-HOWTO (you can find this in the directory
   '/usr/doc/faq/howto' in Slackware 3.3) gets the two computers talking
   to each other. Other alternatives are PLIP or a null modem cable, but
   network cards are easy to come by nowadays. (Note: network cards with
   RJ45 interfaces can connect two computers together if you make a
   crossover cable, it works for me.)
   
   Once the computers are talking you can use ftp or even Samba to
   transfer files, as well as mounting various drives and partitions by
   NFS. All good clean fun. But the ideal way to maintain a "mirror" of
   your home directories so you don't lose any precious datafiles is to
   use 'rdist'. (Note: the following describes a Slackware 3.3 setup but
   the procedure should give the rest of you a start.) Firstly you must
   amend the file 'hosts.equiv' on the "backup" machine (i.e. the one you
   are going to back-up the files to) to allow users to 'rlogin' (see the
   man page for 'rlogin') to the "backup" computer from the "main"
   computer without having to supply a password. 'hosts.equiv' is found
   in '/etc' (Slackware), the stock 'hosts.equiv' has one entry,
   'localhost'. Simply add the relevant name or IP address for your
   "main" computer (go back and read the NET-3-HOWTO, you know you have
   to) on a new line. If you have accounts (same user name) on both
   machines, you are now able to 'rlogin' to the "backup" from the "main"
   with the command 'rlogin <other_computer_name>' and it should not
   demand a password (unless you are 'root', but you don't want to mess
   around letting 'root' rlogin without a password, do you?).
   
   Now you're cooking with gas. Make a file called 'distfile' in your
   home directory on your "main" computer. Here's one I made earlier--
   

HOSTS = ( johnny@pod )
FILES = ( ~/ )
EXCEPT = ( ~/.netscape ~/\(PROG\) ~/StarOffice-3.1 ~/.trash ~/.bash_history )

${FILES} -> ${HOSTS}
        install -oremove,chknfs,younger ;
        except ${EXCEPT} ;

   Now's the time for you to consult 'man rdist' to see what all this
   means. The first three lines set variables - it is possible to give
   'rdist' command line switches to modify these, so it could be helpful
   when you get more adventurous. The last three lines are commands for
   'rdist'. The 'install' command copies/deletes files/directories as
   specified. The 'except' command omits the specified files/directories
   from processing. (If you specify a directory it means that directory's
   files and subdirectories and files.) The '->' line tells it what to
   where. Note the 'host' is the "backup" computer and given of the form
   'user@domain'. This should be an account you can 'rlogin' to without
   needing a password (modify 'hosts.equiv' see above). If you look at
   the above example, it says,
   
     "Copy the entire home directory to "pod," excepting the Netscape
     cache directory, the trash directory, the StarOffice stuff and the
     .bash_history file."
     
   The switches to 'install' say,
   
     "Remove any files on the backup that aren't on the main machine,
     don't follow through NFS links, and don't update files on the
     backup machine that are younger than the equivalent on the main
     machine."
     
   Note how 'remove'and 'younger' interact: 'remove' will remove any
   orphan files, so 'younger' won't keep brand new files on the backup
   that haven't been made on the main machine - decide what you want! In
   the case of a backup to an account you don't use then 'younger' isn't
   really necessary. If it's an account you do use, then don't use
   'remove' but do use 'younger'.
   
   A perusal of the 'rdist' man page should make this all clear. Having
   made the 'distfile,' all you have to do to synchronize the files on
   your two machines is type 'rdist' at the prompt on the "main" machine
   and it will go ahead and do it all for you and tell you about it.
   'rdist' will create directories as needed, preserve permissions,
   ownerships etc., will only change files that don't match (you can
   alter the criteria it uses to decide this, see the 'man' page). It is
   excellent! Run 'rdist' regularly and you need never "lose" your
   data-files. Even better if you back-up over the Internet to a remote
   location.
   
   Now you can go back to Gerd's article and see how he uses his script
   to keep his laptop and desktop in synch. A study of the 'rdist' man
   page will make evident that 'rdist' has great power and flexibility
   for the adventurous. There really is no excuse for not backing up your
   work!
     _________________________________________________________________
   
   
    John Pate
    
   Last modified: Sat May 2 12:25:18 BST 1998
     _________________________________________________________________
   
                        Copyright  1998, John Pate
             Published in Issue 29 of Linux Gazette, June 1998
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back Next 
     _________________________________________________________________
   
                          Linux Gazette Back Page
                                      
           Copyright  1998 Specialized Systems Consultants, Inc.
For information regarding copying and distribution of this material see the
                              Copying License.
     _________________________________________________________________
   
  Contents:
  
     * About This Month's Authors
     * Not Linux
     _________________________________________________________________
   
                         About This Month's Authors
     _________________________________________________________________
   
    Tom Bryant
    
   Tom has been working with computers since 1978. Since then, I wrote my
   thesis (on emission lines in planetary nebulae) on an Apple II, wrote
   the telemetry processing program with which NASA deduced some of the
   early problems with the space telescope (its direct descendant is
   still in use today), and lately a program that fixes a serious
   telemetry formatting error on the EOS AM-1 satellite. I've written
   programs that display tesseracts, simulate a star cluster with
   accurate stellar motions, implement a new language (related to forth),
   and play the piano! My interests include (in alphabetical order) 35mm
   photography, the American Civil war, Astronomy, Beethoven, Chopin,
   Classical piano, Cryptography, Explorer post 1275, Fixing old cars,
   History, Mathematics, Rachmaninov, Science, Single Malt Scotch, Sports
   cars, Telescope making... My wife and I have 2 kids, 2 cars, 2 birds
   and 1 18 year old cat.
   
    Jim Dennis
    
   Jim is the proprietor of Starshine Technical Services. His
   professional experience includes work in the technical support,
   quality assurance, and information services (MIS) departments of
   software companies like Quarterdeck, Symantec/ Peter Norton Group, and
   McAfee Associates -- as well as positions (field service rep) with
   smaller VAR's. He's been using Linux since version 0.99p10 and is an
   active participant on an ever-changing list of mailing lists and
   newsgroups. He's just started collaborating on the 2nd Edition for a
   book on Unix systems administration. Jim is an avid science fiction
   fan -- and was married at the World Science Fiction Convention in
   Anaheim. His wife, Heather Stern, is now doing the HTML for his
   column.
   
    Michael Hamilton
    
   Michael has been working as a freelance Unix C/C++ developer since
   1989. More recently he's been working on web applications and Unix
   server administration. Michael tripped over one of Linus's postings
   back at the beginning of 1992 and has been hooked ever since.
   
    Phil Hughes
    
   Phil Hughes is the publisher of Linux Journal, and thereby Linux
   Gazette. He dreams of permanently telecommuting from his home on the
   Pacific coast of the Olympic Peninsula. As an employer, he is
   "Vicious, Evil, Mean, & Nasty, but kind of mellow" as a boss should
   be.
   
    Andy Kahn
    
   Andy Kahn is currently a graduate student in Computer Science at UCLA,
   praying to finish his Masters degree sometime in the foreseeable near
   future. His primary research area is in parallel I/O. On the side,
   Andy also does Unix System Administration at Activision, a well-known
   computer games company. He also has had previous jobs, including
   system administration as well as programming by masquerading as a
   Software Engineer. Andy has been an on and off Linux enthusiast since
   his first SLS v1.02 installation over 3 years ago.
   
    Eric Marsden
    
   Eric is studying computer science in Toulouse, France, and is a member
   of the local Linux Users Group. He enjoys programming, cycling and Led
   Zeppelin. He admits to once having owned a Macintosh, but denies any
   connection with the the Eric Conspiracy Secret Labs.
   
    David Nelson
    
   David manages scientific research at the U.S. Department of Energy.
   Before that he earned his living as a theoretical plasma physicist. He
   started programming on the IBM 650 using absolute machine language and
   later graduated to CDC, DEC and Cray machines for his research. But
   Linux is the most fun. He and his wife, Kathy, live near Washington
   DC; they enjoy tennis, skiing, sailing, music, theater and good food.
   
    John Pate
    
   John works part-time at Caf Cyberia Edinburgh and is looking for a
   full-time job in Unix System Administration. John has a first degree
   in Psychology and has been playing on the Internet since he first
   discovered it in the late eighties. Having worked for a while
   programming for Windows 3.1x he decided Linux was the way forward. He
   can be contacted at johnny@dvc.org.uk and his homepage is at
   http://www.dvc.org.uk/johnny
     _________________________________________________________________
   
                                 Not Linux
     _________________________________________________________________
   
   [INLINE] Thanks to all our authors, not just the ones above, but also
   those who wrote giving us their tips and tricks and making
   suggestions. Thanks also to our new mirror sites. And a special thanks
   to Heather Stern for the great job she is doing on htmlizing "The
   Answer Guy". It looks good and she's saving me a lot of work. :-)
   
   My wonderful father-in-law, Ralph Richardson, has moved to Seattle
   from Southern California. He's been here almost 2 weeks now and it's
   been fun helping him get settled in and seeing him on a much more
   frequent basis. I know we'll get used to him being here all the time,
   but right now getting to see so much of him feels like vacation. And I
   can use as much vacation as I can get! :-)
   
   Have fun!
     _________________________________________________________________
   
   Marjorie L. Richardson
   Editor, Linux Gazette, gazette@ssc.com
   Linux Gazette Issue 29, June 1998, http://www.linuxgazette.com
     _________________________________________________________________
   
   [ TABLE OF CONTENTS ] [ FRONT PAGE ] Back 
     _________________________________________________________________
   
   This page written and maintained by the Editor of Linux Gazette,
   gazette@ssc.com
