Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 11 Nov 2010 18:19:34 -0700
From:      Chad Perrin <perrin@apotheon.com>
To:        freebsd-questions@freebsd.org
Subject:   Re: Tips for installing windows and freeBSD both.. anyone??
Message-ID:  <20101112011934.GC35128@guilt.hydra>
In-Reply-To: <AANLkTi=KNcjf6bo52=D9ioh7c8Fu%2BTHOzusvEdA_KRt6@mail.gmail.com>
References:  <201011100009.oAA09mfG024502@mail.r-bonomi.com> <AANLkTi=KNcjf6bo52=D9ioh7c8Fu%2BTHOzusvEdA_KRt6@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help

--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 <bonomi@mail.r-bonomi.com> 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--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20101112011934.GC35128>