From owner-freebsd-questions@FreeBSD.ORG Fri Nov 12 01:25:45 2010 Return-Path: Delivered-To: freebsd-questions@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 26B8E106564A for ; Fri, 12 Nov 2010 01:25:45 +0000 (UTC) (envelope-from perrin@apotheon.com) Received: from cpoproxy2-pub.bluehost.com (cpoproxy2-pub.bluehost.com [67.222.39.38]) by mx1.freebsd.org (Postfix) with SMTP id E90458FC0A for ; Fri, 12 Nov 2010 01:25:44 +0000 (UTC) Received: (qmail 28391 invoked by uid 0); 12 Nov 2010 01:25:44 -0000 Received: from unknown (HELO box543.bluehost.com) (74.220.219.143) by cpoproxy2.bluehost.com with SMTP; 12 Nov 2010 01:25:44 -0000 DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; s=default; d=apotheon.com; h=Date:From:To:Subject:Message-ID:Mail-Followup-To:References:Mime-Version:Content-Type:Content-Disposition:In-Reply-To:User-Agent:X-Identified-User; b=iPOUCWjsKEumhPiZAJ6Pq8cysHDZhEg1z9/xrWNADOwv0NOMlH6gzkibWQxZS3/ZNvU4MkoK8w9KT60tmzD6dPvGIRJ5bbYEG9+AilVmlXJcRiZi+TqoOLgdAG13sQ+o; Received: from c-24-8-180-234.hsd1.co.comcast.net ([24.8.180.234] helo=kukaburra.hydra) by box543.bluehost.com with esmtpsa (TLSv1:AES256-SHA:256) (Exim 4.69) (envelope-from ) id 1PGiOd-00076z-7F for freebsd-questions@freebsd.org; Thu, 11 Nov 2010 18:25:44 -0700 Received: by kukaburra.hydra (sSMTP sendmail emulation); Thu, 11 Nov 2010 18:19:34 -0700 Date: Thu, 11 Nov 2010 18:19:34 -0700 From: Chad Perrin To: freebsd-questions@freebsd.org Message-ID: <20101112011934.GC35128@guilt.hydra> Mail-Followup-To: freebsd-questions@freebsd.org References: <201011100009.oAA09mfG024502@mail.r-bonomi.com> Mime-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="yVhtmJPUSI46BTXb" Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.4.2.3i X-Identified-User: {2737:box543.bluehost.com:apotheon:apotheon.org} {sentby:smtp auth 24.8.180.234 authed with ren@apotheon.org} Subject: Re: Tips for installing windows and freeBSD both.. anyone?? X-BeenThere: freebsd-questions@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: User questions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 12 Nov 2010 01:25:45 -0000 --yVhtmJPUSI46BTXb Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Tue, Nov 09, 2010 at 06:10:54PM -0800, Rob Farmer wrote: > On Tue, Nov 9, 2010 at 16:09, Robert Bonomi wr= ote: > > A GUI provids a =A0_fixed_ set of predefined operations that it is poss= ible to > > perform. > > > > IF your needs are met =3Dentirely=3D by the provided operations, great.= =A0If not, > > you're dead in the water, without any way to accomplish the task. >=20 > How is this different from the command line? If I have a set of data > and want to sort it in a way that "sort" doesn't have an argument for, > I'm just as dead in the water as with the GUI. In fact, with the GUI I > am probably better off because I can see that this is not supported > within the program, without having to use the documentation. It is different in that multiple tools are easily chained together via the Unix pipeline, whereas a single GUI has to encompass all of the actions possible to perform at a single time, thus resulting in a far more narrow set of limitations on what can reasonably be provided as options. In fact, a set of CLI filters linked together by the Unix pipeline (or even a DOS pipeline, at least in theory) is essentially infinitely extensible to provide surprising levels of automation customizability that might astonish the earlier creators of some of the older tools being used, while an extension system for a GUI application necessarily has to predefine what is possible, and obfuscates the inner workings of the extended application behind designs that are largely opaque to the user. > > > > GUIs are great for the casual user, because they provide a consistent '= look&feel' > > acrross the spectrum of apps available under them, and, _generally_ wha= t you > > learn =A0from using one application 'generalizes' to any other app that= runs under > > the same GUI. > > > > OTOH, a GUI is the worst thing in the world for 'production' use. =A0It= absolutely > > _kills_ productivity for production tasks. =A0Automation for productivi= ty _REQUIRES_ > > a complete/comprehensive command =A0language. > > > > With a command language, you can 'automate' a series of operations by s= imply > > listing the commands in a file, and feeding that file to the command-pr= ocessor > > input. > > > > With a GUI there is no way to describe the series of mouse 'motions'/'c= licks'/ > > 'double-clicks'/'drags' and keypresses required to perform an operation. > > 'screen coordinates' are meaningless when a window, or icon, or button,= may be > > 'repositioned' at will. > > > > An _individual_ application may allow scripting via an internal command= language, > > but since it is internal to the app, and *not* part of the GUI, it does= n't > > 'generalize' (no guarantee that similar capability is present in any ot= her app) > > *AND* is utterly worthless for 'automating' annything that involves mor= e than > > the single app. >=20 > The CLI doesn't generalize either. How many ways are there to get > input into a program? You might be surprised by how many different ways of getting data into a program can be accomplished with a simple Perl idiom like this: while (<>) { } It gets pretty generalized in a hurry. >=20 > On the other hand, 99% of GUI apps that handle files have a File > > Open dialog that is provided via a toolkit and works the same > everywhere. =2E . . and it is shortly after that point that things get very specific, and non-general. >=20 > > > > Years ago, I worked at a place that, among other things, produced a ref= erence > > manual of statistical data for our cusotmers. =A0About 800 pages of tab= ular data, > > practically all of it updated on a staggered, monthly basis. =A0In the = 'early' > > days (MS-DOS vintage, before 'windows'), =A0each table was kept in a se= parate > > spreadsheet, which _did_ require the redundant entry of a _small_ amoun= t of > > the data. OTOH two (or more) differnt people could be updatdin differen= t paes > > simultaneously, regardless of whether or not they were 'related'. =A0An= d, at > > the end of the week, when it was time to send out the weeks 'updates' t= o the > > customers, =A0we had a simple little '.BAT file, each line of which; (a= ) invoked > > the spreadsheet =A0(b) specified the spreadsheet file to use, and (c) i= nvoked > > a 'start-up macro' that printed the contents of the spreadseet, and exi= ted > > the program. =A0Thus, on 'publication' day it was just type in the name= of the > > '.BAT file and everthing got printed. =A0It took an hour or two -- of _= machine_time_ > > that is, but _zero_ human intervention. > > > > Fast forward a few years, =A0a new-hire analyist (in a senior capacity)= felt > > humiliated at having to use this 'old' technology (they had Windows at = his > > prior employer), and made a big enough stink about it that the shop upg= raded > > to Windows just to keep him happy. He proceeds to bundle all 'his' spre= adsheets > > into a single workbook, so that only one person can be working on any o= f them > > at any given time, and, on 'publication day', somebody had to sit there= and > > click on each relevant/changed =A0sheet in the workbook, click on' file= ', click > > on print, select the page to print, and click 'doit'. =A0 What a *wonde= rful* > > productivity increase!! =A0We've now got a system that requires a -huma= n- to > > play babysitttr the machine. =A0For a couple of -hours- every week. =A0= all to save > > the complainer from having to enter a few numbers redundantly. >=20 > This isn't really a GUI problem, because the issue is the file format > changing such that your .bat no longer worked. If you retained the > original format or fixed the script, it would still work fine. Actually, my understanding was that the problem was someone refused to type a simple command, and would rather make a series of seven clicks thirty times while babysitting the application, and had no conception of the benefits of letting more than one person work in parallel on a given task. It wasn't the file format that changed; it was someone's tolerance for using a keyboard instead of a mouse. This is the kind of thinking that leads to the Mac defaulting to a mouse with only one button. >=20 > However, it still points out one of the biggest problems with the CLI > - there is a barrier to entry in knowing what commands to run with > what arguments to make everything work the way you want. File > Print > was easy for your office staff to figure out. The CLI equivalent > apparently wasn't. That was not evident in the explanation of what happened. The explanation suggested nothing about the batch file in question being difficult to use (or "figure out"). From the sound of it, three instructions on a 3x5 card would have sufficed to ensure everybody knew what to do, except in the case of people who do not know how to operate a keyboard. >=20 > I think many here are underestimating the value of GUIs, because they > have been running many of these traditional UNIX commands for years > (or decades) and are also technically oriented enough that learning > them in the first place wasn't a big deal. I think that GUIs are quite valuable when used where appropriate. I think that the rest of the time, people greatly exaggerate the value of the GUI, to the extent that they begin to think the CLI (as well as TUIs in general) has no value at all. I used to be one of those idiots, and there was a time when I would have been on your side of this little debate. That was almost fifteen years ago. Times change, and I grow in knowledge and experience. The end result is that I believe those who are competent to operate a computer professionally would benefit from learning how to use the command line for those tasks that are more efficiently performed without the GUI mediating the experience, at least for almost any task that is performed with any regularity at all. Obviously, many tasks related to visually oriented work like image editing are excepted from this. Such tasks are a minority, however, where non-casual use is concerned. --=20 Chad Perrin [ original content licensed OWL: http://owl.apotheon.org ] --yVhtmJPUSI46BTXb Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.14 (FreeBSD) iEYEARECAAYFAkzcliYACgkQ9mn/Pj01uKWbLwCg5NAoJKyBC+ZyOettPWGlelBo XP0AoLS9r+0eZETo1z62tP+8e1HHEEYh =A4bj -----END PGP SIGNATURE----- --yVhtmJPUSI46BTXb--