Common User Access (CUA) is a standard for
user interface
In the industrial design field of human–computer interaction, a user interface (UI) is the space where interactions between humans and machines occur. The goal of this interaction is to allow effective operation and control of the machine f ...
s to
operating system
An operating system (OS) is system software that manages computer hardware, software resources, and provides common daemon (computing), services for computer programs.
Time-sharing operating systems scheduler (computing), schedule tasks for ef ...
s and
computer program
A computer program is a sequence or set of instructions in a programming language for a computer to execute. Computer programs are one component of software, which also includes documentation and other intangible components.
A computer progra ...
s. It was developed by
IBM and first published in 1987 as part of their
Systems Application Architecture. Used originally in the
MVS/ESA
Multiple Virtual Storage, more commonly called MVS, was the most commonly used operating system on the System/370 and System/390 IBM mainframe computers. IBM developed MVS, along with OS/VS1 and SVS, as a successor to OS/360. It is unrelated ...
,
VM/CMS,
OS/400,
OS/2
OS/2 (Operating System/2) is a series of computer operating systems, initially created by Microsoft and IBM under the leadership of IBM software designer Ed Iacobucci. As a result of a feud between the two companies over how to position OS/2 ...
and
Microsoft Windows operating systems, parts of the CUA standard are now implemented in programs for other operating systems, including variants of
Unix
Unix (; trademarked as UNIX) is a family of multitasking, multiuser computer operating systems that derive from the original AT&T Unix, whose development started in 1969 at the Bell Labs research center by Ken Thompson, Dennis Ritchie, a ...
. It is also used by
Java
Java (; id, Jawa, ; jv, ꦗꦮ; su, ) is one of the Greater Sunda Islands in Indonesia. It is bordered by the Indian Ocean to the south and the Java Sea to the north. With a population of 151.6 million people, Java is the world's mo ...
AWT and
Swing
Swing or swinging may refer to:
Apparatus
* Swing (seat), a hanging seat that swings back and forth
* Pendulum, an object that swings
* Russian swing, a swing-like circus apparatus
* Sex swing, a type of harness for sexual intercourse
* Swing rid ...
.
Motivations and inspirations
IBM wanted a standard way to interact with
text-based user interface software, whether the screen was a
dumb terminal
A computer terminal is an electronic or electromechanical hardware device that can be used for entering data into, and transcribing data from, a computer or a computing system. The teletype was an example of an early-day hard-copy terminal ...
connected to a mainframe or a
PS/2
The Personal System/2 or PS/2 is IBM's second generation of personal computers. Released in 1987, it officially replaced the IBM PC, XT, AT, and PC Convertible in IBM's lineup. Many of the PS/2's innovations, such as the 16550 UART (serial po ...
with
VGA graphics. CUA was a detailed specification and set strict rules about how applications should look and function. Its aim was in part to bring about harmony among
DOS applications, which until then had independently implemented different user interfaces.
For example, to open a file:
* In
WordPerfect, the command to open a file was , .
* In
Lotus 1-2-3
Lotus 1-2-3 is a discontinued spreadsheet program from Lotus Software (later part of IBM). It was the first killer application of the IBM PC, was hugely popular in the 1980s, and significantly contributed to the success of IBM PC-compatible ...
, a file was opened with (to open the menus), (for File), (for Retrieve).
* In
Microsoft Word
Microsoft Word is a word processing software developed by Microsoft. It was first released on October 25, 1983, under the name ''Multi-Tool Word'' for Xenix systems. Subsequent versions were later written for several other platforms includi ...
, a file was opened with (to open the menus), (for Transfer), (for Load).
* In
WordStar
WordStar is a word processor application for microcomputers. It was published by MicroPro International and originally written for the CP/M-80 operating system, and later written also for MS-DOS and other 16-bit computing, 16-bit PC OSes. Rob Ba ...
, (to get to the ''Opening Menu''), followed by .
* In
emacs
Emacs , originally named EMACS (an acronym for "Editor MACroS"), is a family of text editors that are characterized by their extensibility. The manual for the most widely used variant, GNU Emacs, describes it as "the extensible, customizable, ...
, a file is opened with + followed by + (for find-file).
* In
vi, use to allow commands, then to open the file browser.
was often the
help key (such as
Volkswriter (1982)
), but in WordPerfect, help was on instead. Some programs used to cancel an action, while some used it to complete one; WordPerfect used it to repeat a character. Some programs used to go to the end of a line, while some used it to complete filling in a form. sometimes toggled between overtype and inserting characters, but some programs used it for "paste".
Thus every program had to be learned individually and its complete user interface memorised. It was a sign of expertise to have learned the UIs of dozens of applications, since a novice user facing a new program would find their existing knowledge of a similar application either of no use or actively a hindrance to understanding as learned behavior might need to be unlearned for the new application.
The detailed CUA specification, published in December 1987, is 328 pages long. It has similarities to
Apple Computer
Apple Inc. is an American multinational technology company headquartered in Cupertino, California, United States. Apple is the largest technology company by revenue (totaling in 2021) and, as of June 2022, is the world's biggest company ...
's detailed
human interface guidelines (139 pages).
The Apple HIG is a detailed book specifying how software for the 1984
Apple Macintosh
The Mac (known as Macintosh until 1999) is a family of personal computers designed and marketed by Apple Inc. Macs are known for their ease of use and minimalist designs, and are popular among students, creative professionals, and software ...
computer should look and function.
When it was first written, the Mac was new, and
graphical user interface
The GUI ( "UI" by itself is still usually pronounced . or ), graphical user interface, is a form of user interface that allows User (computing), users to Human–computer interaction, interact with electronic devices through graphical icon (comp ...
(GUI) software was a novelty, so Apple took great pains to ensure that programs would conform to a single shared look and feel. CUA had a similar aim, but it faced the more difficult task of trying to impose this retroactively on an existing, thriving but chaotic industry, with the much more ambitious goal of unifying all UI, from personal computers to minicomputers to mainframes; and supporting both character and GUI modes, and both batch and interactive designs. By comparison, the Apple HIG only supported interactive GUI on a standalone personal computer. CUA also attempted to be a more measurable standard than the Apple HIG and had large sections formatted as checklists to measure compliance.
Description
The CUA contains standards for the operation of elements such as
dialog box
The dialog box (also called dialogue box (non-U.S. English), message box or simply dialog) is a graphical control element in the form of a small window that communicates information to the user and prompts them for a response.
Dialog boxes ar ...
es,
menus and
keyboard shortcut
computing, a keyboard shortcut also known as hotkey is a series of one or several keys to quickly invoke a software program or perform a preprogrammed action. This action may be part of the standard functionality of the operating system or ...
s that have become so influential that they are implemented today by many programmers who have never read the CUA.
Some of these standards can be seen in the operation of Windows itself and DOS-based applications like the MS-DOS 5 full-screen
text editor
A text editor is a type of computer program that edits plain text. Such programs are sometimes known as "notepad" software (e.g. Windows Notepad). Text editors are provided with operating systems and software development packages, and can be u ...
edit.com. CUA hallmarks include:
* All operations can be done with either the
mouse
A mouse ( : mice) is a small rodent. Characteristically, mice are known to have a pointed snout, small rounded ears, a body-length scaly tail, and a high breeding rate. The best known mouse species is the common house mouse (''Mus musculus' ...
or the
keyboard;
* If applicable to the page/screen in question provides a refresh function;
* Menus are activated/deactivated with the key;
* Menus are opened by pressing the key plus the underlined letter of the menu name;
* Menu commands that require parameters to proceed are suffixed with an
ellipsis
The ellipsis (, also known informally as dot dot dot) is a series of dots that indicates an intentional omission of a word, sentence, or whole section from a text without altering its original meaning. The plural is ellipses. The term origin ...
("…");
* Options are requested using secondary windows (often called dialog boxes);
* Options are divided into sections using notebook tabs;
* Navigation within fields in dialog boxes is by cursor key; navigation between fields is by pressing the key; + moves backwards;
* Dialog boxes have a 'Cancel' button, activated by pressing the key, which discards changes, and an 'OK' button, activated by pressing , which accepts changes;
* Applications have
online help
Online help is topic-oriented, procedural or reference information delivered through computer software. It is a form of user assistance. The purpose of most online help is to assist in using a software application, web application or operating syst ...
accessed by a Help menu, which is the last option on the menu bar; context sensitive help can be summoned by ;
* The first menu is to be called 'File' and contains operations for handling files (new, open, save, save as) as well as quitting the program; the next menu 'Edit' has commands for undo, redo, cut, copy, delete, paste commands;
* The
Cut command is +;
Copy is +;
Paste
Paste is a term for any very thick viscous fluid. It may refer to:
Science and technology
* Adhesive or paste
** Wallpaper paste
** Wheatpaste, A liquid adhesive made from vegetable starch and water
* Paste (rheology), a substance that behaves a ...
is +;
* The size of a window can be changed by dragging one of the 8 segments of the border.
CUA not only covers DOS applications, but is also the basis for the Windows Consistent User Interface standard (CUI), as well as that for OS/2 applications — both text-mode and the
Presentation Manager GUI — and IBM mainframes which conform to the
Systems Application Architecture.
CUA was more than just an attempt to rationalise DOS applications — it was part of a larger scheme to bring together, rationalise and harmonise the overall functions of software and hardware across IBM's entire computing range from microcomputers to mainframes.
The third edition of CUA took a radical departure from the first two by introducing the
object-oriented
Object-oriented programming (OOP) is a programming paradigm based on the concept of " objects", which can contain data and code. The data is in the form of fields (often known as attributes or ''properties''), and the code is in the form of ...
workplace
A workplace is a location where someone works, for their employer or themselves, a place of employment. Such a place can range from a home office to a large office building or factory. For industrialized societies, the workplace is one of ...
. This changed the emphasis of the user's interactions to be the data (documents, pictures, and so on) that the user worked on. The emphasis on applications was removed with the intention of making the computer easier to use by matching users' expectations that they would work on documents using programs (rather than operating programs to work on documents). (See also
object-oriented user interface.)
Influence
CUA strongly influenced the early
Microsoft Windows operating system during the period of joint IBM and Microsoft cooperation on OS/2 Presentation Manager. But later releases of IBM's CUA documents were not used for Microsoft products, and so CUA became less significant in the Windows environment. For instance, the
Start menu
The Start menu is a graphical user interface element used in Microsoft Windows since Windows 95 and in other operating systems. It provides a central launching point for computer programs and performing other tasks in the Windows shell. It is na ...
was introduced. Most of the standard keystrokes and basic GUI widgets specified by the CUA remain available in Windows. The well-known combination for closing a window, , stems from CUA.
CUA never had significant impact on the design of
Unix
Unix (; trademarked as UNIX) is a family of multitasking, multiuser computer operating systems that derive from the original AT&T Unix, whose development started in 1969 at the Bell Labs research center by Ken Thompson, Dennis Ritchie, a ...
terminal (character-mode) applications, which preceded CUA by more than a decade. However, all major Unix GUI environments/toolkits, whether or not based on the
X Window System
The X Window System (X11, or simply X) is a windowing system for bitmap displays, common on Unix-like operating systems.
X provides the basic framework for a GUI environment: drawing and moving windows on the display device and interacting ...
, have featured varying levels of CUA compatibility, with Motif/
CDE CDE may refer to:
Education
* California Department of Education
* Career Development Event, a type of contest sponsored by the National FFA Organization
* Center for Data Engineering, IIIT Hyderabad
* Center for Distance Education at University of ...
explicitly featuring it as a design goal. The current major environments,
GNOME and
KDE, also feature extensive CUA compatibility. The subset of CUA implemented in
Microsoft Windows or
OSF/Motif is generally considered a
de facto standard
A ''de facto'' standard is a custom or convention that has achieved a dominant position by public acceptance or market forces (for example, by early entrance to the market). is a Latin phrase (literally "in fact"), here meaning "in practice but ...
to be followed by any new Unix GUI environment.
See also
*
Table of keyboard shortcuts
References
* IBM, Systems Application Architecture: Common User Access: Panel Design and User Interaction, Document SC26-4351-0, 1987.
* IBM, Systems Application Architecture: Common User Access: Advanced Interface Design Guide, Document SC26-4582-0, 1990.
* IBM, Systems Application Architecture: Common User Access: Basic Interface Design Guide, Document SC26-4583-0
1992. (Partial archive)
* IBM, Systems Application Architecture: Common User Access: Guide to User Interface Design, Document SC34-4289-00 199
* IBM, Systems Application Architecture: Common User Access: Advanced Interface Design Reference, Document SC34-4290-00 199
*
External links
* , by
Richard E. Berry
Richard is a male given name. It originates, via Old French, from Old Frankish and is a compound of the words descending from Proto-Germanic ''*rīk-'' 'ruler, leader, king' and ''*hardu-'' 'strong, brave, hardy', and it therefore means 'strong ...
,
IBM Systems Journal, Volume 27, Nº 3, 1988
Citations This link is down, PDF still available at: https://web.archive.org/web/20070927082756/http://www.research.ibm.com/journal/sj/273/ibmsj2703E.pdf
* , by Richard E. Berry,
Cliff J. Reeves
In geography and geology, a cliff is an area of rock which has a general angle defined by the vertical, or nearly vertical. Cliffs are formed by the processes of weathering and erosion, with the effect of gravity. Cliffs are common on coa ...
, IBM Systems Journal, Volume 31, Nº 3, 1992
Citations
* , by Richard E. Berry, IBM Systems Journal, Volume 31, Nº 3, 1992
Citations
IBM BookManager SAA CUA bookshelf1992
CUA Window Emulation for SlickEdit- A table of CUA-based hotkeys provided by a
SlickEdit mode
{{OS/2
Common User Access
Human–computer interaction
User interface techniques
Common User Access