KeyboardMap.st
author claus
Mon, 06 Feb 1995 01:38:04 +0100
changeset 89 ea2bf46eb669
parent 72 3e84121988c3
child 219 9ff0660f447f
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
48194c26a46c Initial revision
claus
parents:
diff changeset
     1
"
48194c26a46c Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
     3
	      All Rights Reserved
0
48194c26a46c Initial revision
claus
parents:
diff changeset
     4
48194c26a46c Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
48194c26a46c Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
48194c26a46c Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
48194c26a46c Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
48194c26a46c Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
48194c26a46c Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
48194c26a46c Initial revision
claus
parents:
diff changeset
    11
"
48194c26a46c Initial revision
claus
parents:
diff changeset
    12
48194c26a46c Initial revision
claus
parents:
diff changeset
    13
IdentityDictionary  subclass:#KeyboardMap 
48194c26a46c Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'current'
48194c26a46c Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
48194c26a46c Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
48194c26a46c Initial revision
claus
parents:
diff changeset
    17
       category:'Interface-Support'
48194c26a46c Initial revision
claus
parents:
diff changeset
    18
!
48194c26a46c Initial revision
claus
parents:
diff changeset
    19
48194c26a46c Initial revision
claus
parents:
diff changeset
    20
KeyboardMap comment:'
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    21
COPYRIGHT (c) 1993 by Claus Gittinger
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    22
	      All Rights Reserved
54
29a6b2f8e042 *** empty log message ***
claus
parents: 46
diff changeset
    23
89
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    24
$Header: /cvs/stx/stx/libview/KeyboardMap.st,v 1.6 1995-02-06 00:37:29 claus Exp $
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    25
'!
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    26
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    27
!KeyboardMap class methodsFor:'documentation'!
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    28
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    29
copyright
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    30
"
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    31
 COPYRIGHT (c) 1993 by Claus Gittinger
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
    32
	      All Rights Reserved
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    33
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    34
 This software is furnished under a license and may be used
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    35
 only in accordance with the terms of that license and with the
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    37
 be provided or otherwise made available to, or used by, any
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    38
 other person.  No title to or ownership of the software is
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    39
 hereby transferred.
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    40
"
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    41
!
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    42
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    43
version
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    44
"
89
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    45
$Header: /cvs/stx/stx/libview/KeyboardMap.st,v 1.6 1995-02-06 00:37:29 claus Exp $
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    46
"
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    47
!
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    48
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    49
documentation
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    50
"
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    51
    instances of KeyboardMap are used for mapping keystrokes AND sequences
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    52
    of keystrokes to a function key.
89
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    53
    There is usually only one instance in the system - held in an instance
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    54
    variable of Display.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    55
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    56
    The setup of this map is done in the 'smalltalk.rc' or one of the
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    57
    'display.rc' files during startup.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    58
    To add a mapping (for example, to attach the logical function 'DoIt' to
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    59
    the key-combination Cmd-'d'):
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    60
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    61
	|m|
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    62
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    63
	m := Display keyboardMap.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    64
	m bindValue:#DoIt to:#Cmdd.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    65
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    66
    Key sequences can also be defined (hey emacs fans ;-) as in:
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    67
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    68
	|m|
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    69
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    70
	m := Display keyboardMap.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    71
	m bindValue:#DoIt to:#Ctrlx followedBy:#Ctrld
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    72
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    73
    Key prefixes are defined in the DeviceWorkstation>>translateKey: method.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    74
    Typical prefixes are Cmd (for Alt or Meta), Ctrl etc.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    75
    Some keyboards offer both Alt and Meta keys - on those, the first has a
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    76
    prefix of Alt, the second has Cmd as prefix. Keyboards with only an Alt
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    77
    key will will create prefix codes of Cmd for that.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    78
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    79
    To remove a mapping, use the same value for both logical and physical key,
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    80
    as in:
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    81
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    82
	|m|
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    83
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    84
	m := Display keyboardMap.
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    85
	m bindValue:#Cmdd to:#Cmdd.
46
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    86
"
7b331e9012fd *** empty log message ***
claus
parents: 5
diff changeset
    87
! !
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    88
48194c26a46c Initial revision
claus
parents:
diff changeset
    89
!KeyboardMap methodsFor:'accessing'!
48194c26a46c Initial revision
claus
parents:
diff changeset
    90
89
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    91
bindValue:logicalKey to:aKey
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    92
    aKey == logicalKey ifTrue:[
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    93
	self removeKey:aKey
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    94
    ] ifFalse:[
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    95
	self at:aKey put:logicalKey
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    96
    ]
0
48194c26a46c Initial revision
claus
parents:
diff changeset
    97
!
48194c26a46c Initial revision
claus
parents:
diff changeset
    98
89
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
    99
bindValue:logicalKey to:key1 followedBy:key2
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   100
    |submap|
48194c26a46c Initial revision
claus
parents:
diff changeset
   101
89
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
   102
    submap := self at:key1 ifAbsent:[].
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   103
    submap isNil ifTrue:[
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   104
	submap := KeyboardMap new.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   105
	self at:key1 put:submap.
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   106
    ].
89
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
   107
    submap at:key2 put:logicalKey
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   108
!
48194c26a46c Initial revision
claus
parents:
diff changeset
   109
48194c26a46c Initial revision
claus
parents:
diff changeset
   110
valueFor:aKey
48194c26a46c Initial revision
claus
parents:
diff changeset
   111
    |where value|
48194c26a46c Initial revision
claus
parents:
diff changeset
   112
89
ea2bf46eb669 *** empty log message ***
claus
parents: 72
diff changeset
   113
    where := (current notNil ifTrue:[current] ifFalse:[self]).
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   114
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   115
    value := where at:aKey ifAbsent:aKey.
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   116
    (value isMemberOf:KeyboardMap) ifTrue:[
72
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   117
	current := value.
3e84121988c3 *** empty log message ***
claus
parents: 54
diff changeset
   118
	^ nil.
0
48194c26a46c Initial revision
claus
parents:
diff changeset
   119
    ].
48194c26a46c Initial revision
claus
parents:
diff changeset
   120
    current := nil.
48194c26a46c Initial revision
claus
parents:
diff changeset
   121
    ^ value
48194c26a46c Initial revision
claus
parents:
diff changeset
   122
! !