ugBASIC 1.18
An isomorphic BASIC language compiler for retrocomputers
Loading...
Searching...
No Matches
input.c
Go to the documentation of this file.
1/*****************************************************************************
2 * ugBASIC - an isomorphic BASIC language compiler for retrocomputers *
3 *****************************************************************************
4 * Copyright 2021-2026 Marco Spedaletti (asimov@mclink.it)
5 *
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 *----------------------------------------------------------------------------
18 * Concesso in licenza secondo i termini della Licenza Apache, versione 2.0
19 * (la "Licenza"); è proibito usare questo file se non in conformità alla
20 * Licenza. Una copia della Licenza è disponibile all'indirizzo:
21 *
22 * http://www.apache.org/licenses/LICENSE-2.0
23 *
24 * Se non richiesto dalla legislazione vigente o concordato per iscritto,
25 * il software distribuito nei termini della Licenza è distribuito
26 * "COSÌ COM'È", SENZA GARANZIE O CONDIZIONI DI ALCUN TIPO, esplicite o
27 * implicite. Consultare la Licenza per il testo specifico che regola le
28 * autorizzazioni e le limitazioni previste dalla medesima.
29 ****************************************************************************/
30
31/****************************************************************************
32 * INCLUDE SECTION
33 ****************************************************************************/
34
35#include "../../ugbc.h"
36
37/****************************************************************************
38 * CODE SECTION
39 ****************************************************************************/
40
41extern char DATATYPE_AS_STRING[][16];
42
43void input( Environment * _environment, char * _variable, VariableType _default_type ) {
44
46
47 Variable * result;
48 if ( variable_exists( _environment, _variable ) ) {
49 result = variable_retrieve( _environment, _variable );
50 } else {
51 result = variable_define( _environment, _variable, _default_type, 0 );
52 }
53
54 char repeatLabel[MAX_TEMPORARY_STORAGE]; sprintf(repeatLabel, "%srepeat", label );
55 char finishedLabel[MAX_TEMPORARY_STORAGE]; sprintf(finishedLabel, "%sfinished", label );
56 char backspaceLabel[MAX_TEMPORARY_STORAGE]; sprintf(backspaceLabel, "%sbackspace", label );
57
58 Variable * temporary = variable_temporary( _environment, VT_DSTRING, "(temporary storage for input)");
59 Variable * offset = variable_temporary( _environment, VT_BYTE, "(offset inside temporary storage)");
60
61 Variable * enter = variable_temporary( _environment, VT_CHAR, "(enter)" );
62 Variable * comma = variable_temporary( _environment, VT_CHAR, "(comma)" );
63 Variable * space = variable_temporary( _environment, VT_CHAR, "(space)" );
64 Variable * underscore = variable_temporary( _environment, VT_CHAR, "(underscore)" );
65 Variable * backspace = variable_temporary( _environment, VT_CHAR, "(backspace)" );
66 Variable * size = variable_temporary( _environment, VT_BYTE, "(size max)" );
67 Variable * pressed = variable_temporary( _environment, VT_BYTE, "(key pressed?)");
68 Variable * key = variable_temporary( _environment, VT_CHAR, "(key pressed)");
69 Variable * zero = variable_temporary( _environment, VT_BYTE, "(zero)" );
70
71 cpu_store_8bit( _environment, enter->realName, 13 );
72 cpu_store_8bit( _environment, offset->realName, 0 );
73 cpu_store_8bit( _environment, backspace->realName, 20 );
74 cpu_store_8bit( _environment, space->realName, 32 );
75 cpu_store_8bit( _environment, zero->realName, 0 );
76
77 cpu_store_8bit( _environment, comma->realName, _environment->keyboardConfig.separator == 0 ? INPUT_DEFAULT_SEPARATOR : _environment->keyboardConfig.separator );
78 cpu_store_8bit( _environment, size->realName, _environment->keyboardConfig.size == 0 ? INPUT_DEFAULT_SIZE : _environment->keyboardConfig.size );
79 cpu_store_8bit( _environment, underscore->realName, _environment->keyboardConfig.cursor == 0 ? INPUT_DEFAULT_CURSOR : _environment->keyboardConfig.cursor );
80
81 Variable * address = variable_temporary( _environment, VT_ADDRESS, "(address of DSTRING)");
82 cpu_dsfree( _environment, temporary->realName );
83 cpu_dsalloc( _environment, size->realName, temporary->realName );
84 cpu_dsdescriptor( _environment, temporary->realName, address->realName, pressed->realName );
85
86 cpu_label( _environment, repeatLabel );
87
88 print( _environment, underscore->name, 0, _environment->printRaw );
89 cmove_direct( _environment, -1, 0 );
90
91 coleco_inkey( _environment, pressed->realName, key->realName );
92
93 cpu_bveq( _environment, pressed->realName, repeatLabel );
94 cpu_bveq( _environment, key->realName, repeatLabel );
95
96 cpu_compare_8bit( _environment, key->realName, backspace->realName, pressed->realName, 1 );
97
98 cpu_bvneq( _environment, pressed->realName, backspaceLabel );
99
100 cpu_compare_8bit( _environment, key->realName, comma->realName, pressed->realName, 1 );
101
102 cpu_bvneq( _environment, pressed->realName, finishedLabel );
103
104 cpu_compare_8bit( _environment, key->realName, enter->realName, pressed->realName, 1 );
105
106 cpu_bvneq( _environment, pressed->realName, finishedLabel );
107
108 print( _environment, key->name, 0, _environment->printRaw );
109
110 cpu_move_8bit_indirect_with_offset2( _environment, key->realName, address->realName, offset->realName );
111
112 cpu_inc( _environment, offset->realName );
113
114 cpu_compare_8bit( _environment, offset->realName, size->realName, pressed->realName, 1 );
115
116 cpu_bveq( _environment, pressed->realName, repeatLabel );
117
118 cpu_jump( _environment, finishedLabel );
119
120 cpu_label( _environment, backspaceLabel );
121
122 cpu_compare_8bit( _environment, offset->realName, zero->realName, pressed->realName, 1 );
123
124 cpu_bvneq( _environment, pressed->realName, repeatLabel );
125
126 cpu_dec( _environment, offset->realName );
127
128 print( _environment, space->name, 0, _environment->printRaw );
129
130 cmove_direct( _environment, -2, 0 );
131
132 print( _environment, space->name, 0, _environment->printRaw );
133
134 cmove_direct( _environment, -1, 0 );
135
136 cpu_jump( _environment, repeatLabel );
137
138 cpu_label( _environment, finishedLabel );
139
140 print( _environment, space->name, 0, _environment->printRaw );
141 cmove_direct( _environment, -1, 0 );
142
143 cpu_dsresize( _environment, temporary->realName, offset->realName );
144
145 switch( VT_BITWIDTH( result->type ) ) {
146 case 8:
147 case 16:
148 case 32:
149 variable_move( _environment, variable_string_val( _environment, temporary->name )->name, result->name );
150 break;
151 case 0:
152 switch( result->type ) {
153 case VT_DSTRING:
154 variable_move_naked( _environment, temporary->name, result->name );
155 break;
156 default:
157 CRITICAL_INPUT_UNSUPPORTED( _variable, DATATYPE_AS_STRING[result->type] );
158 }
159 }
160
161}
void cpu_dsfree(Environment *_environment, char *_index)
Definition 6309.c:5917
void cpu_bveq(Environment *_environment, char *_value, char *_label)
Definition 6309.c:334
void cpu_dsresize(Environment *_environment, char *_index, char *_resize)
Definition 6309.c:5937
void cpu_compare_8bit(Environment *_environment, char *_source, char *_destination, char *_other, int _positive)
CPU 6309: emit code to compare two 8 bit values
Definition 6309.c:811
void cpu_inc(Environment *_environment, char *_variable)
Definition 6309.c:4555
void cpu_move_8bit_indirect_with_offset2(Environment *_environment, char *_source, char *_value, char *_offset)
Definition 6309.c:5262
void cpu_label(Environment *_environment, char *_label)
Definition 6309.c:356
void cpu_dec(Environment *_environment, char *_variable)
Definition 6309.c:4630
void cpu_dsalloc(Environment *_environment, char *_size, char *_index)
Definition 6309.c:5895
void cpu_store_8bit(Environment *_environment, char *_destination, int _value)
CPU 6309: emit code to store 8 bit
Definition 6309.c:761
void cpu_jump(Environment *_environment, char *_label)
Definition 6309.c:3739
void cpu_bvneq(Environment *_environment, char *_value, char *_label)
Definition 6309.c:345
void cpu_dsdescriptor(Environment *_environment, char *_index, char *_address, char *_size)
Definition 6309.c:5977
Variable * variable_retrieve(Environment *_environment, char *_name)
int variable_exists(Environment *_environment, char *_name)
Variable * variable_string_val(Environment *_environment, char *_value)
Emit code for = VAL( ... ).
Variable * variable_move(Environment *_environment, char *_source, char *_destination)
Store the value of a variable inside another variable by converting it.
Variable * variable_move_naked(Environment *_environment, char *_source, char *_destination)
Store the value of a variable inside another variable without conversion.
Variable * variable_define(Environment *_environment, char *_name, VariableType _type, int _value)
Define a variable for the program.
Variable * variable_temporary(Environment *_environment, VariableType _type, char *_meaning)
Define a temporary variable.
int size
Definition _optimizer.c:678
int offset
Definition _optimizer.c:681
void input(Environment *_environment, char *_variable, VariableType _default_type)
Definition input.c:43
#define INPUT_DEFAULT_SEPARATOR
Definition atari.h:133
#define INPUT_DEFAULT_SIZE
Definition atari.h:134
#define INPUT_DEFAULT_CURSOR
Definition atari.h:135
void cmove_direct(Environment *_environment, int _dx, int _dy)
Definition cmove.c:41
void coleco_inkey(Environment *_environment, char *_pressed, char *_key)
void print(Environment *_environment, char *_value, int _new_line, int _raw)
Emit code for PRINT... instruction.
Definition print.c:141
KeyboardConfig keyboardConfig
Definition ugbc.h:2435
int printRaw
Definition ugbc.h:3274
char separator
Definition ugbc.h:1982
char * name
Definition ugbc.h:979
char * realName
Definition ugbc.h:982
#define MAX_TEMPORARY_STORAGE
Definition ugbc.h:563
struct _Variable Variable
Structure of a single variable.
#define CRITICAL_INPUT_UNSUPPORTED(v, t)
Definition ugbc.h:3490
struct _Environment Environment
Structure of compilation environment.
@ VT_BYTE
Definition ugbc.h:450
@ VT_CHAR
Definition ugbc.h:498
@ VT_ADDRESS
Definition ugbc.h:465
@ VT_DSTRING
Definition ugbc.h:483
enum _VariableType VariableType
Type of variables.
#define VT_BITWIDTH(t)
Definition ugbc.h:595
#define MAKE_LABEL
Definition ugbc.h:3351
char DATATYPE_AS_STRING[][16]