[comp.os.vms] Curses and SMG

ynguyen@hawk.CS.ULowell.Edu (Lone Ranger) (07/15/87)

Could somebody comment about the merits of :
1) Curses
2) the Screen management routines
Performance? Bugs(if any)? Functionality? How easy they are to use? 
Would you recommend Curses or SMG to program games like rogue, hack?

Thanks in advance.
Y. Nguyen

mhg@MITRE-BEDFORD.ARPA (Mark H. Granoff) (07/16/87)

>Could somebody comment about the merits of :
>1) Curses
>2) the Screen management routines

I can't comment on 'curses' but I can comment (quite verbosely) on
SMG.  We use it here for development and I wrote a Window Manager that
uses the SMG library of routines.

>Performance? Bugs(if any)? Functionality? How easy they are to use? 
>Would you recommend Curses or SMG to program games like rogue, hack?

Performance:
     I would have to say that SMG's performance is dependant on what
     kind of terminal you are using and how loaded the system is.  (By
     the way, SMG is pretty much terminal independent).

     There are ways to improve SMG's performance (through SMG calls).
     For example, selecting 'minimal update' when a pasteboard is
     created insures that only portions of the screen that change will
     be updated.  There are other means too.

Bugs:
     There are none that I know of -- but it certainly adheres to the
     rule that computers do what you *say* and not what you *mean*.

Functionality and Ease of Use:
     SMG is not easy to use.  Once you learn a good subset of routine
     names, it still is not easy to use (except that you'll know which
     routines do what).

     There are so many routines that it's difficult to keep straight
     the myriad of parameters that each one has.  In addition, the
     routine names are less than intuitive.

     I beleive that one of the best uses for SMG is window management,
     but the idea of 'pasteboards' and 'displays' is certainly much
     less obvious than 'screens' and 'windows'.  This is the reason
     that I wrote a Window Manager which has routines like
     'create_window' and 'open_window'.

     Once you get an application going that uses SMG, it will usually
     be *very* spiffy.  You can do some neat stuff.

As I said above, I don't know anything about 'curses'; DEC suggests
that all new (screen oriented) development use SMG (rather than direct
cursor addressing and escape sequences).  [There is an SMG routine
that tells SMG to use escape sequences].

Hope this is helpful.

+---------------------------------------------------------------------+
| Mark H. Granoff                       Member of the Technical Staff |
+---------------------------------------------------------------------+
| USMAIL: The MITRE Corporation   | ARPAnet: mhg @ mitre-bedford.ARPA |
|         Burlington Rd. M/S B015 |-----------------------------------|
|         Bedford, MA 01730       | A T & T: (617) 271 - 7030         |
+--------------------------- Disclaimer ------------------------------+ 
|The views expressed herein are my own and do not necessarily reflect |
|                      those of my employer.                          |
+---------------------------------------------------------------------+
|  Unix commands are based on the principle of intuitive complexity.  |
+---------------------------------------------------------------------+

rterrell@ncoast.UUCP (Roger Terrell) (07/21/87)

>Could somebody comment about the merits of :
>1) Curses
>2) the Screen management routines
>Performance? Bugs(if any)? Functionality? How easy they are to use? 
>Would you recommend Curses or SMG to program games like rogue, hack?

I haven't used the Curses package much, but the SMG routines are very
good for certain things, and are not hard to use.  They have a lot of
useful things that I don't *think* are in Curses (broadcast trapping, etc.).

On the other hand, they are not well suited for things like rogue or hack
simply because they would tend to be slow for the kind of screen
updating, etc. in that type of game.

Roger Terrell
UUCP: ...cbosgd!musky2!terrell
CSNet:  ccterrell%muskingum.edu@relay.cs.net

nagy%warner.hepnet@LBL.ARPA (07/22/87)

>Could somebody comment about the merits of :
>1) Curses
>2) the Screen management routines
     
I've not written much to use either VAX C Curses or SMG but have studied
both (others here a busy writing applications using SMG).

SMG seems, from reading the documentation, to be very, very powerful.
The VAX DEBUGger uses SMG in screen mode; the performance and utility
seems very good.

VAX C Curses actually is a layer on top of SMG, however Curses does not
take advantage of all the functionality of SMG.  Curses seems most
useful for writing portable software or porting software to VMS from
UNIX.  I'd certainly rather use SMG directly, even from VAX C, except
when maybe throwing together one of those "quick and dirties".


= Frank J. Nagy
= Fermilab Research Division EED/Controls
= HEPNET: WARNER::NAGY (43198::NAGY) or FNAL::NAGY (43009::NAGY)
= BitNet: NAGY@FNAL
= USnail: Fermilab POB 500 MS/220 Batavia, IL 60510

EVERHART%ARISIA@rca.COM ("GLENN EVERHART, 609 486 6328") (07/23/87)

While it is true that DEC supplies a version of the curses package
that runs under SMG, there ARE alternatives. One such is the curses
package that's part of GNU Emacs. That's independent of SMG and is
probably closer to the Un*x original. I have no idea how its performance
compares with SMG, but if you are looking for a curses package that 
might conceivably be speedier than SMG, or that might avoid any
SMG bugs (and introduce other bugs of its own?), that might be worth
a look. The S87 VAX SIG tape has the code, and the 1987 L&T SIG tape
from DECUS will also. The VAX tape (Spring '87) can be ordered from
the DECUS library 617 480 3418. Look in [VAX87B.GNUEMXV18...]...
	Glenn Everhart
	RCA A+D Technology, Bldg. 206-1
	Rt. 38
	Cherry Hill NJ 08358
	609 486 6328
Everhart%Arisia.decnet@ge-crd.arpa