PrintConverter.st
author Claus Gittinger <cg@exept.de>
Thu, 25 Apr 1996 18:35:11 +0200
changeset 222 c51b06f6bf9a
parent 212 874afdeb380a
child 223 b65dc250db8d
permissions -rw-r--r--
documentation
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
75
claus
parents: 69
diff changeset
     1
"
claus
parents: 69
diff changeset
     2
 COPYRIGHT (c) 1995 by Claus Gittinger
claus
parents: 69
diff changeset
     3
	      All Rights Reserved
claus
parents: 69
diff changeset
     4
claus
parents: 69
diff changeset
     5
 This software is furnished under a license and may be used
claus
parents: 69
diff changeset
     6
 only in accordance with the terms of that license and with the
claus
parents: 69
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
claus
parents: 69
diff changeset
     8
 be provided or otherwise made available to, or used by, any
claus
parents: 69
diff changeset
     9
 other person.  No title to or ownership of the software is
claus
parents: 69
diff changeset
    10
 hereby transferred.
claus
parents: 69
diff changeset
    11
"
claus
parents: 69
diff changeset
    12
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    13
Object subclass:#PrintConverter
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    14
	instanceVariableNames:'valueToStringBlock stringToValueBlock type'
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    15
	classVariableNames:''
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    16
	poolDictionaries:''
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    17
	category:'Interface-Support'
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    18
!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    19
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    20
!PrintConverter class methodsFor:'documentation'!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    21
75
claus
parents: 69
diff changeset
    22
copyright
claus
parents: 69
diff changeset
    23
"
claus
parents: 69
diff changeset
    24
 COPYRIGHT (c) 1995 by Claus Gittinger
claus
parents: 69
diff changeset
    25
	      All Rights Reserved
claus
parents: 69
diff changeset
    26
claus
parents: 69
diff changeset
    27
 This software is furnished under a license and may be used
claus
parents: 69
diff changeset
    28
 only in accordance with the terms of that license and with the
claus
parents: 69
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
claus
parents: 69
diff changeset
    30
 be provided or otherwise made available to, or used by, any
claus
parents: 69
diff changeset
    31
 other person.  No title to or ownership of the software is
claus
parents: 69
diff changeset
    32
 hereby transferred.
claus
parents: 69
diff changeset
    33
"
claus
parents: 69
diff changeset
    34
!
claus
parents: 69
diff changeset
    35
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    36
documentation
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    37
"
86
claus
parents: 83
diff changeset
    38
    printConverters can be used with labels and editFields to convert 
claus
parents: 83
diff changeset
    39
    an object to/from some printed representation.
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    40
    Conversion is done via two blocks which can be set at instance
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    41
    creation time - either as custom blocks ot to one of the
86
claus
parents: 83
diff changeset
    42
    standard conversions. There are a number of standard setups, for
claus
parents: 83
diff changeset
    43
    common conversions; if none of them fits your needs, create a custom
claus
parents: 83
diff changeset
    44
    converter, by defining its two conversion blocks.
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    45
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    46
    Notice: this class was implemented using protocol information
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    47
    from alpha testers - it may not be complete or compatible to
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    48
    the corresponding ST-80 class. If you encounter any incompatibilities,
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    49
    please forward a note to the ST/X team.
222
c51b06f6bf9a documentation
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
    50
c51b06f6bf9a documentation
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
    51
    [author:]
c51b06f6bf9a documentation
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
    52
        Claus Gittinger
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    53
"
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    54
!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    55
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    56
examples 
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    57
"
86
claus
parents: 83
diff changeset
    58
  stupid examples:
claus
parents: 83
diff changeset
    59
    convert date <-> string:
claus
parents: 83
diff changeset
    60
69
claus
parents: 68
diff changeset
    61
      |conv|
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    62
69
claus
parents: 68
diff changeset
    63
      conv := (PrintConverter new)
claus
parents: 68
diff changeset
    64
		  toPrint:[:date | date printString]
claus
parents: 68
diff changeset
    65
		  toRead:[:string | Date readFromString:string].
claus
parents: 68
diff changeset
    66
      (conv printStringFor:(Date today)) inspect.
claus
parents: 68
diff changeset
    67
      (conv readValueFrom:(Date today printString)) inspect
claus
parents: 68
diff changeset
    68
claus
parents: 68
diff changeset
    69
86
claus
parents: 83
diff changeset
    70
    convert number <-> string:
claus
parents: 83
diff changeset
    71
69
claus
parents: 68
diff changeset
    72
      |conv|
claus
parents: 68
diff changeset
    73
claus
parents: 68
diff changeset
    74
      conv := (PrintConverter new) initForNumber.
claus
parents: 68
diff changeset
    75
      (conv printStringFor:12345) inspect.
claus
parents: 68
diff changeset
    76
      (conv readValueFrom:'12345') inspect
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    77
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    78
86
claus
parents: 83
diff changeset
    79
    convert boolean <-> string:
claus
parents: 83
diff changeset
    80
69
claus
parents: 68
diff changeset
    81
      |conv|
claus
parents: 68
diff changeset
    82
claus
parents: 68
diff changeset
    83
      conv := (PrintConverter new) initForYesNo.
claus
parents: 68
diff changeset
    84
      (conv printStringFor:true).  
claus
parents: 68
diff changeset
    85
      (conv printStringFor:false).    
claus
parents: 68
diff changeset
    86
      (conv readValueFrom:'yes').  
claus
parents: 68
diff changeset
    87
      (conv readValueFrom:'no').  
claus
parents: 68
diff changeset
    88
      'if language is german:'.
claus
parents: 68
diff changeset
    89
      (conv readValueFrom:'ja').    
claus
parents: 68
diff changeset
    90
      (conv readValueFrom:'nein')  
claus
parents: 68
diff changeset
    91
86
claus
parents: 83
diff changeset
    92
  concrete examples: 
claus
parents: 83
diff changeset
    93
    convert in an inputField:
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
    94
69
claus
parents: 68
diff changeset
    95
      |dialog field|
claus
parents: 68
diff changeset
    96
claus
parents: 68
diff changeset
    97
      dialog := Dialog new.
claus
parents: 68
diff changeset
    98
      dialog addTextLabel:'a number (and only numbers):'.
claus
parents: 68
diff changeset
    99
      dialog addVerticalSpace.
claus
parents: 68
diff changeset
   100
      field := dialog addInputFieldOn:(0 asValue).
claus
parents: 68
diff changeset
   101
      field converter:(PrintConverter new initForNumber).
claus
parents: 68
diff changeset
   102
      field immediateAccept:true.
claus
parents: 68
diff changeset
   103
      dialog addOkButton.
claus
parents: 68
diff changeset
   104
      dialog open.
claus
parents: 68
diff changeset
   105
      dialog accepted ifTrue:[
claus
parents: 68
diff changeset
   106
	  Transcript showCr:field editValue
claus
parents: 68
diff changeset
   107
      ]
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   108
86
claus
parents: 83
diff changeset
   109
    convert a models value for a label:
claus
parents: 83
diff changeset
   110
claus
parents: 83
diff changeset
   111
      |top v1 v2 l1 l2|
claus
parents: 83
diff changeset
   112
claus
parents: 83
diff changeset
   113
      v1 := 0 asValue.
claus
parents: 83
diff changeset
   114
      v2 := Date today asValue.
claus
parents: 83
diff changeset
   115
claus
parents: 83
diff changeset
   116
      top := StandardSystemView new.
claus
parents: 83
diff changeset
   117
      top extent:200@200.
claus
parents: 83
diff changeset
   118
claus
parents: 83
diff changeset
   119
      l1 := Label origin:0.0@0.0 corner:1.0@0.5 in:top.
claus
parents: 83
diff changeset
   120
      l1 converter:(PrintConverter new initForInteger).
claus
parents: 83
diff changeset
   121
      l1 model:v1; labelMessage:#value; aspect:#value.
claus
parents: 83
diff changeset
   122
      l1 level:-1; inset:10.
claus
parents: 83
diff changeset
   123
claus
parents: 83
diff changeset
   124
      l2 := Label origin:0.0@0.5 corner:1.0@1.0 in:top.
claus
parents: 83
diff changeset
   125
      l2 converter:(PrintConverter new initForDate).
claus
parents: 83
diff changeset
   126
      l2 model:v2; labelMessage:#value; aspect:#value.
claus
parents: 83
diff changeset
   127
      l2 level:-1; inset:10.
claus
parents: 83
diff changeset
   128
claus
parents: 83
diff changeset
   129
      top open.
claus
parents: 83
diff changeset
   130
claus
parents: 83
diff changeset
   131
      'now, change the values ...'.
claus
parents: 83
diff changeset
   132
      [
claus
parents: 83
diff changeset
   133
	1 to:50 do:[:i|
claus
parents: 83
diff changeset
   134
	    v1 value:(v1 value + 1).
claus
parents: 83
diff changeset
   135
	    v2 value:(v2 value addDays:1).
claus
parents: 83
diff changeset
   136
	    (Delay forSeconds:0.5) wait
claus
parents: 83
diff changeset
   137
	]
claus
parents: 83
diff changeset
   138
      ] fork
claus
parents: 83
diff changeset
   139
claus
parents: 83
diff changeset
   140
    convert a models value for a label with limited precision
claus
parents: 83
diff changeset
   141
    float conversion:
claus
parents: 83
diff changeset
   142
claus
parents: 83
diff changeset
   143
      |top v l1 l2|
claus
parents: 83
diff changeset
   144
claus
parents: 83
diff changeset
   145
      v := 0.0 asValue.
claus
parents: 83
diff changeset
   146
claus
parents: 83
diff changeset
   147
      top := StandardSystemView new.
claus
parents: 83
diff changeset
   148
      top extent:200@200.
claus
parents: 83
diff changeset
   149
claus
parents: 83
diff changeset
   150
      l1 := Label origin:0.0@0.0 corner:1.0@0.5 in:top.
claus
parents: 83
diff changeset
   151
      l1 converter:(PrintConverter new initForFloat).
claus
parents: 83
diff changeset
   152
      l1 model:v; labelMessage:#value; aspect:#value.
claus
parents: 83
diff changeset
   153
      l1 level:-1; inset:10.
claus
parents: 83
diff changeset
   154
claus
parents: 83
diff changeset
   155
      l2 := Label origin:0.0@0.5 corner:1.0@1.0 in:top.
claus
parents: 83
diff changeset
   156
      l2 converter:(PrintConverter new initForFloatWithPrecision:2).
claus
parents: 83
diff changeset
   157
      l2 model:v; labelMessage:#value; aspect:#value.
claus
parents: 83
diff changeset
   158
      l2 level:-1; inset:10.
claus
parents: 83
diff changeset
   159
claus
parents: 83
diff changeset
   160
      top open.
claus
parents: 83
diff changeset
   161
claus
parents: 83
diff changeset
   162
      'now, change the values ...'.
claus
parents: 83
diff changeset
   163
      [
claus
parents: 83
diff changeset
   164
	1 to:100 do:[:i|
claus
parents: 83
diff changeset
   165
	    v value:(v value + 0.005).
claus
parents: 83
diff changeset
   166
	    (Delay forSeconds:0.5) wait
claus
parents: 83
diff changeset
   167
	]
claus
parents: 83
diff changeset
   168
      ] fork
claus
parents: 83
diff changeset
   169
claus
parents: 83
diff changeset
   170
    a custom converter, converting a number to either 'odd'
claus
parents: 83
diff changeset
   171
    or 'even' strings (we only need a one-way converter for labels):
claus
parents: 83
diff changeset
   172
claus
parents: 83
diff changeset
   173
      |top v l1 l2|
claus
parents: 83
diff changeset
   174
claus
parents: 83
diff changeset
   175
      v := 0 asValue.
claus
parents: 83
diff changeset
   176
claus
parents: 83
diff changeset
   177
      top := StandardSystemView new.
claus
parents: 83
diff changeset
   178
      top extent:200@200.
claus
parents: 83
diff changeset
   179
claus
parents: 83
diff changeset
   180
      l1 := Label origin:0.0@0.0 corner:1.0@0.5 in:top.
claus
parents: 83
diff changeset
   181
      l1 converter:(PrintConverter new initForInteger).
claus
parents: 83
diff changeset
   182
      l1 model:v; labelMessage:#value; aspect:#value.
claus
parents: 83
diff changeset
   183
      l1 level:-1; inset:10.
claus
parents: 83
diff changeset
   184
claus
parents: 83
diff changeset
   185
      l2 := Label origin:0.0@0.5 corner:1.0@1.0 in:top.
claus
parents: 83
diff changeset
   186
      l2 converter:(PrintConverter 
claus
parents: 83
diff changeset
   187
		      new 
claus
parents: 83
diff changeset
   188
			  toPrint:[:num | num even ifTrue:['even'] 
claus
parents: 83
diff changeset
   189
						   ifFalse:['odd']]
claus
parents: 83
diff changeset
   190
			  toRead:[:string | ]).
claus
parents: 83
diff changeset
   191
      l2 model:v; labelMessage:#value; aspect:#value.
claus
parents: 83
diff changeset
   192
      l2 level:-1; inset:10.
claus
parents: 83
diff changeset
   193
claus
parents: 83
diff changeset
   194
      top open.
claus
parents: 83
diff changeset
   195
claus
parents: 83
diff changeset
   196
      'now, change the values ...'.
claus
parents: 83
diff changeset
   197
      [
claus
parents: 83
diff changeset
   198
	1 to:100 do:[:i|
claus
parents: 83
diff changeset
   199
	    v value:(v value + 1).
claus
parents: 83
diff changeset
   200
	    (Delay forSeconds:0.5) wait
claus
parents: 83
diff changeset
   201
	]
claus
parents: 83
diff changeset
   202
      ] fork
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   203
69
claus
parents: 68
diff changeset
   204
    see more examples in the EditField examples.
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   205
"
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   206
! !
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   207
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   208
!PrintConverter class methodsFor:'instance creation'!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   209
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   210
new
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   211
    ^ (super new) 
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   212
	toPrint:[:val | val]
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   213
	toRead:[:string | string]
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   214
! !
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   215
86
claus
parents: 83
diff changeset
   216
!PrintConverter class methodsFor:'utilities'!
claus
parents: 83
diff changeset
   217
claus
parents: 83
diff changeset
   218
print:aNumber formattedBy:formatString
claus
parents: 83
diff changeset
   219
    "take the digits of aNumbers printString, and squash them
claus
parents: 83
diff changeset
   220
     into formatString, where #-characters are replaced by
claus
parents: 83
diff changeset
   221
     successive characters from the printString.
claus
parents: 83
diff changeset
   222
     Warning: use with care - it does not check for decimal points etc.
claus
parents: 83
diff changeset
   223
	      the printString of aNumber must have enough digits for all
claus
parents: 83
diff changeset
   224
	      #-characters to be replaced.
claus
parents: 83
diff changeset
   225
	      Therefore, precheck the numbers value and use appropriate format
claus
parents: 83
diff changeset
   226
	      strings then.
claus
parents: 83
diff changeset
   227
     For number formatting, see also: printfPrintString: implementations."
claus
parents: 83
diff changeset
   228
claus
parents: 83
diff changeset
   229
    |pS fS out|
claus
parents: 83
diff changeset
   230
claus
parents: 83
diff changeset
   231
    pS := ReadStream on:aNumber printString.
claus
parents: 83
diff changeset
   232
    fS := ReadStream on:formatString.
claus
parents: 83
diff changeset
   233
    out := WriteStream on:String new.
claus
parents: 83
diff changeset
   234
    [fS atEnd] whileFalse:[
claus
parents: 83
diff changeset
   235
	|c|
claus
parents: 83
diff changeset
   236
claus
parents: 83
diff changeset
   237
	c := fS next.
claus
parents: 83
diff changeset
   238
	c == $# ifTrue:[
claus
parents: 83
diff changeset
   239
	    c := pS next
claus
parents: 83
diff changeset
   240
	].
claus
parents: 83
diff changeset
   241
	out nextPut:c
claus
parents: 83
diff changeset
   242
    ].
claus
parents: 83
diff changeset
   243
    ^ out contents
claus
parents: 83
diff changeset
   244
claus
parents: 83
diff changeset
   245
    "
claus
parents: 83
diff changeset
   246
     PrintConverter print:'123456789' formattedBy:'US$ ###,###.##' 
claus
parents: 83
diff changeset
   247
claus
parents: 83
diff changeset
   248
    fails for:
claus
parents: 83
diff changeset
   249
     PrintConverter print:'1234' formattedBy:'US$ ###,###.##' 
claus
parents: 83
diff changeset
   250
claus
parents: 83
diff changeset
   251
    invalid string for:
claus
parents: 83
diff changeset
   252
     PrintConverter print:'123456789' formattedBy:'US$ ###' 
claus
parents: 83
diff changeset
   253
    "
claus
parents: 83
diff changeset
   254
! !
claus
parents: 83
diff changeset
   255
100
claus
parents: 96
diff changeset
   256
!PrintConverter methodsFor:'accessing'!
claus
parents: 96
diff changeset
   257
claus
parents: 96
diff changeset
   258
type
claus
parents: 96
diff changeset
   259
    "return the type if its one of the standard converters,
claus
parents: 96
diff changeset
   260
     #number, #string etc. nil otherwise"
claus
parents: 96
diff changeset
   261
claus
parents: 96
diff changeset
   262
    ^ type
claus
parents: 96
diff changeset
   263
! !
claus
parents: 96
diff changeset
   264
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   265
!PrintConverter methodsFor:'converting'!
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   266
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   267
printStringFor:aValue
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   268
    "sent when an inputField wants a models value to be converted to a string
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   269
     for display"
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   270
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   271
    ^ valueToStringBlock value:aValue
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   272
!
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   273
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   274
readValueFrom:aString
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   275
    "sent when an inputField wants a string to be converted to a value 
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   276
     to be returned as its contents value"
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   277
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   278
    ^ stringToValueBlock value:aString
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   279
! !
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   280
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   281
!PrintConverter methodsFor:'initialization'!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   282
100
claus
parents: 96
diff changeset
   283
initFor:aTypeSymbol
claus
parents: 96
diff changeset
   284
    "initialize to convert to/from objects as specified by aTypeSymbol,
claus
parents: 96
diff changeset
   285
     which may be one of #number, #string, #symbol, #date or #password ..."
claus
parents: 96
diff changeset
   286
claus
parents: 96
diff changeset
   287
    aTypeSymbol == #number ifTrue:[
claus
parents: 96
diff changeset
   288
	self initForNumber
claus
parents: 96
diff changeset
   289
    ].
claus
parents: 96
diff changeset
   290
    (aTypeSymbol == #string or:[aTypeSymbol == #password]) ifTrue:[
claus
parents: 96
diff changeset
   291
	self initForString
claus
parents: 96
diff changeset
   292
    ].
claus
parents: 96
diff changeset
   293
    aTypeSymbol == #date ifTrue:[
claus
parents: 96
diff changeset
   294
	self initForDate
claus
parents: 96
diff changeset
   295
    ].
claus
parents: 96
diff changeset
   296
    aTypeSymbol == #symbol ifTrue:[
claus
parents: 96
diff changeset
   297
	self initForSymbol
claus
parents: 96
diff changeset
   298
    ].
claus
parents: 96
diff changeset
   299
claus
parents: 96
diff changeset
   300
    type := aTypeSymbol
claus
parents: 96
diff changeset
   301
claus
parents: 96
diff changeset
   302
    "Modified: 6.9.1995 / 12:10:38 / claus"
claus
parents: 96
diff changeset
   303
!
claus
parents: 96
diff changeset
   304
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   305
initForDate
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   306
    "initialize to convert to/from a date 
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   307
     - if the string is empty or invalid, convert to the current date"
69
claus
parents: 68
diff changeset
   308
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   309
    valueToStringBlock := [:date | date printString].
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   310
    stringToValueBlock := [:string | Date readFromString:string onError:[Date today]]
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   311
!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   312
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   313
initForDateOrNil
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   314
    "initialize to convert to/from a date 
69
claus
parents: 68
diff changeset
   315
     - if the string is empty or invalid, convert to nil"
claus
parents: 68
diff changeset
   316
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   317
    valueToStringBlock := [:date | date printString].
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   318
    stringToValueBlock := [:string | Date readFromString:string onError:nil]
69
claus
parents: 68
diff changeset
   319
!
claus
parents: 68
diff changeset
   320
86
claus
parents: 83
diff changeset
   321
initForFloat
claus
parents: 83
diff changeset
   322
    "initialize to convert to/from an float 
claus
parents: 83
diff changeset
   323
     - if the string is empty or invalid, convert to 0"
claus
parents: 83
diff changeset
   324
claus
parents: 83
diff changeset
   325
    valueToStringBlock := [:num | num asFloat printString].
claus
parents: 83
diff changeset
   326
    stringToValueBlock := [:string | Float readFromString:string onError:0]
claus
parents: 83
diff changeset
   327
!
claus
parents: 83
diff changeset
   328
claus
parents: 83
diff changeset
   329
initForFloatWithPrecision:nDigits
claus
parents: 83
diff changeset
   330
    "initialize to convert to/from an float with nDigits after the decimal point
claus
parents: 83
diff changeset
   331
     (truncating remaining digits).
claus
parents: 83
diff changeset
   332
     - if the string is empty or invalid, convert to 0"
claus
parents: 83
diff changeset
   333
claus
parents: 83
diff changeset
   334
    |conv|
claus
parents: 83
diff changeset
   335
claus
parents: 83
diff changeset
   336
    conv := '%.' , nDigits printString , 'f'.
claus
parents: 83
diff changeset
   337
    valueToStringBlock := [:num | num asFloat printfPrintString:conv].
claus
parents: 83
diff changeset
   338
    stringToValueBlock := [:string | Float readFromString:string onError:0]
claus
parents: 83
diff changeset
   339
!
claus
parents: 83
diff changeset
   340
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   341
initForInteger
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   342
    "initialize to convert to/from an integer 
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   343
     - if the string is empty or invalid, convert to 0"
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   344
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   345
    valueToStringBlock := [:num | num truncated printString].
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   346
    stringToValueBlock := [:string | Integer readFromString:string onError:0]
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   347
!
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   348
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   349
initForIntegerOrNil
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   350
    "initialize to convert to/from an integer 
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   351
     - if the string is empty or invalid, convert to nil"
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   352
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   353
    valueToStringBlock := [:num | 
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   354
	num isNil ifTrue:[''] 
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   355
		  ifFalse:[num printString]].
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   356
    stringToValueBlock := [:string | 
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   357
	Integer readFromString:string onError:nil]
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   358
!
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   359
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   360
initForNumber
69
claus
parents: 68
diff changeset
   361
    "initialize to convert to/from a number 
claus
parents: 68
diff changeset
   362
     - if the string is empty or invalid, convert to 0"
claus
parents: 68
diff changeset
   363
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   364
    valueToStringBlock := [:num | num printString].
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   365
    stringToValueBlock := [:string | Number readFromString:string onError:0]
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   366
!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   367
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   368
initForNumberOrNil
69
claus
parents: 68
diff changeset
   369
    "initialize to convert to/from a number 
claus
parents: 68
diff changeset
   370
     - if the string is empty or invalid, convert to nil"
claus
parents: 68
diff changeset
   371
claus
parents: 68
diff changeset
   372
    valueToStringBlock := [:num | 
claus
parents: 68
diff changeset
   373
	num isNil ifTrue:[''] 
claus
parents: 68
diff changeset
   374
		  ifFalse:[num printString]].
claus
parents: 68
diff changeset
   375
    stringToValueBlock := [:string | 
claus
parents: 68
diff changeset
   376
	Number readFromString:string onError:nil]
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   377
!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   378
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   379
initForString
69
claus
parents: 68
diff changeset
   380
    "initialize for a string - this is trivial"
claus
parents: 68
diff changeset
   381
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   382
    valueToStringBlock := [:val | val isNil ifTrue:[''] ifFalse:[val]].
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   383
    stringToValueBlock := [:string | string]
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   384
!
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   385
68
claus
parents: 67
diff changeset
   386
initForYesNo
69
claus
parents: 68
diff changeset
   387
    "initialize to convert a 'yes'/'no' string to/from a boolean 
claus
parents: 68
diff changeset
   388
     The string is supposed to be in the current Language
claus
parents: 68
diff changeset
   389
     (i.e. if german, ja/nein has to be enterred.
claus
parents: 68
diff changeset
   390
     Invalid entries are converted to false."
claus
parents: 68
diff changeset
   391
68
claus
parents: 67
diff changeset
   392
    valueToStringBlock := [:bool | bool ifTrue:[ApplicationModel classResources string:'yes']
claus
parents: 67
diff changeset
   393
					ifFalse:[ApplicationModel classResources string:'no']].
claus
parents: 67
diff changeset
   394
    stringToValueBlock := [:string | string = (ApplicationModel classResources string:'yes')]
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   395
!
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   396
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   397
toPrint:printBlock toRead:readBlock
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   398
    "initialize to convert using two custom blocks.
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   399
     printBlock is supposed to get the objects value as argument,
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   400
     and to return a string.
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   401
     readBlock is supposed to get a string as argument, and return
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   402
     the corresponding object."
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   403
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   404
    valueToStringBlock := printBlock.
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   405
    stringToValueBlock := readBlock.
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   406
! !
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   407
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   408
!PrintConverter class methodsFor:'documentation'!
100
claus
parents: 96
diff changeset
   409
212
874afdeb380a commentary
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   410
version 
222
c51b06f6bf9a documentation
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
   411
    ^ '$Header: /cvs/stx/stx/libview2/PrintConverter.st,v 1.11 1996-04-25 16:34:18 cg Exp $'
67
e48bf03eb059 Initial revision
claus
parents:
diff changeset
   412
! !