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 doneLabel[MAX_TEMPORARY_STORAGE]; sprintf(doneLabel, "%sdone", label );
57 char backspaceLabel[MAX_TEMPORARY_STORAGE]; sprintf(backspaceLabel, "%sbackspace", label );
58
59 Variable * temporary = variable_temporary( _environment, VT_DSTRING, "(temporary storage for input)");
60 Variable * offset = variable_temporary( _environment, VT_BYTE, "(offset inside temporary storage)");
61
62 Variable * enter = variable_temporary( _environment, VT_CHAR, "(enter)" );
63 Variable * comma = variable_temporary( _environment, VT_CHAR, "(comma)" );
64 Variable * space = variable_temporary( _environment, VT_CHAR, "(space)" );
65 Variable * underscore = variable_temporary( _environment, VT_CHAR, "(underscore)" );
66 Variable * backspace = variable_temporary( _environment, VT_CHAR, "(backspace)" );
67 Variable * size = variable_temporary( _environment, VT_BYTE, "(size max)" );
68 Variable * pressed = variable_temporary( _environment, VT_BYTE, "(key pressed?)");
69 Variable * key = variable_temporary( _environment, VT_CHAR, "(key pressed)");
70 Variable * zero = variable_temporary( _environment, VT_BYTE, "(zero)" );
71
72 cpu_store_8bit( _environment, enter->realName, 13 );
73 cpu_store_8bit( _environment, offset->realName, 0 );
74 cpu_store_8bit( _environment, backspace->realName, 8 );
75 cpu_store_8bit( _environment, space->realName, 32 );
76 cpu_store_8bit( _environment, zero->realName, 0 );
77
78 if ( _environment->lineInput ) {
79 cpu_store_8bit( _environment, comma->realName, 13 );
80 } else {
81 cpu_store_8bit( _environment, comma->realName, _environment->keyboardConfig.separator == 0 ? INPUT_DEFAULT_SEPARATOR : _environment->keyboardConfig.separator );
82 }
83
84 cpu_store_8bit( _environment, size->realName, _environment->keyboardConfig.size == 0 ? INPUT_DEFAULT_SIZE : _environment->keyboardConfig.size );
85 cpu_store_8bit( _environment, underscore->realName, _environment->keyboardConfig.cursor == 0 ? INPUT_DEFAULT_CURSOR : _environment->keyboardConfig.cursor );
86
87 Variable * address = variable_temporary( _environment, VT_ADDRESS, "(address of DSTRING)");
88 cpu_dsfree( _environment, temporary->realName );
89 cpu_dsalloc( _environment, size->realName, temporary->realName );
90 cpu_dsdescriptor( _environment, temporary->realName, address->realName, pressed->realName );
91
92 cpu_label( _environment, repeatLabel );
93
94 print( _environment, underscore->name, 0, _environment->printRaw );
95 cmove_direct( _environment, -1, 0 );
96
97 c128z_inkey( _environment, key->realName );
98
99 cpu_bveq( _environment, key->realName, repeatLabel );
100
101 cpu_compare_8bit( _environment, key->realName, backspace->realName, pressed->realName, 1 );
102
103 cpu_bvneq( _environment, pressed->realName, backspaceLabel );
104
105 cpu_compare_8bit( _environment, key->realName, comma->realName, pressed->realName, 1 );
106
107 cpu_bvneq( _environment, pressed->realName, finishedLabel );
108
109 cpu_compare_8bit( _environment, key->realName, enter->realName, pressed->realName, 1 );
110
111 cpu_bvneq( _environment, pressed->realName, finishedLabel );
112
113 print( _environment, key->name, 0, _environment->printRaw );
114
115 cpu_move_8bit_indirect_with_offset2( _environment, key->realName, address->realName, offset->realName );
116
117 cpu_inc( _environment, offset->realName );
118
119 cpu_compare_8bit( _environment, offset->realName, size->realName, pressed->realName, 1 );
120
121 cpu_bveq( _environment, pressed->realName, repeatLabel );
122
123 cpu_jump( _environment, finishedLabel );
124
125 cpu_label( _environment, backspaceLabel );
126
127 cpu_compare_8bit( _environment, offset->realName, zero->realName, pressed->realName, 1 );
128
129 cpu_bvneq( _environment, pressed->realName, repeatLabel );
130
131 cpu_dec( _environment, offset->realName );
132
133 print( _environment, space->name, 0, _environment->printRaw );
134
135 cmove_direct( _environment, -2, 0 );
136
137 print( _environment, space->name, 0, _environment->printRaw );
138
139 cmove_direct( _environment, -1, 0 );
140
141 cpu_jump( _environment, repeatLabel );
142
143 cpu_label( _environment, finishedLabel );
144
145 print( _environment, space->name, 0, _environment->printRaw );
146 cmove_direct( _environment, -1, 0 );
147
148 cpu_compare_8bit( _environment, comma->realName, enter->realName, pressed->realName, 1 );
149 cpu_bveq( _environment, pressed->realName, doneLabel );
150
151 print_newline( _environment );
152
153 cpu_label( _environment, doneLabel );
154
155 cpu_dsresize( _environment, temporary->realName, offset->realName );
156
157 switch( VT_BITWIDTH( result->type ) ) {
158 case 8:
159 case 16:
160 case 32:
161 variable_move( _environment, variable_string_val( _environment, temporary->name )->name, result->name );
162 break;
163 case 0:
164 switch( result->type ) {
165 case VT_DSTRING:
166 variable_move_naked( _environment, temporary->name, result->name );
167 break;
168 default:
169 CRITICAL_INPUT_UNSUPPORTED( _variable, DATATYPE_AS_STRING[result->type] );
170 }
171 }
172
173}
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 c128z_inkey(Environment *_environment, char *_key)
Definition c128z.c:44
void cmove_direct(Environment *_environment, int _dx, int _dy)
Definition cmove.c:41
void print_newline(Environment *_environment)
Emit code for print a single newline.
Definition print.c:422
void print(Environment *_environment, char *_value, int _new_line, int _raw)
Emit code for PRINT... instruction.
Definition print.c:141
int lineInput
Definition ugbc.h:3118
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]