ugBASIC 1.18
An isomorphic BASIC language compiler for retrocomputers
Loading...
Searching...
No Matches
read_data_unsafe.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 read_data_unsafe( Environment * _environment, char * _variable ) {
44
45 Variable * variable;
46 if ( variable_exists( _environment, _variable ) ) {
47 variable = variable_retrieve( _environment, _variable );
48 } else {
49 variable = variable_define( _environment, _variable, _environment->defaultVariableType, 0 );
50 }
51
52 if ( VT_BITWIDTH( variable->type ) > 1 ) {
53 outline0( "LDX DATAPTR" );
54 switch( VT_BITWIDTH( variable->type ) ) {
55 case 32:
56 outline0( "LDD ,X++" );
57 outline1( "STD %s", variable->realName );
58 outline0( "LDD ,X++" );
59 outline1( "STD %s", address_displacement( _environment, variable->realName, "2" ) );
60 break;
61 case 16:
62 outline0( "LDD ,X++" );
63 outline1( "STD %s", variable->realName );
64 break;
65 case 8:
66 outline0( "LDA ,X+" );
67 outline1( "STA %s", variable->realName );
68 break;
69 }
70 outline0( "STX DATAPTR" );
71 } else {
72
74
75 Variable * dataptr = variable_retrieve( _environment, "DATAPTR" );
76
77 switch( VT_BITWIDTH( variable->type ) ) {
78 case 32:
79 cpu_inc_16bit( _environment, dataptr->realName );
80 cpu_move_32bit_indirect2( _environment, dataptr->realName, variable->realName );
81 cpu_inc_16bit( _environment, dataptr->realName );
82 cpu_inc_16bit( _environment, dataptr->realName );
83 cpu_inc_16bit( _environment, dataptr->realName );
84 cpu_inc_16bit( _environment, dataptr->realName );
85 break;
86 case 16:
87 cpu_inc_16bit( _environment, dataptr->realName );
88 cpu_move_16bit_indirect2( _environment, dataptr->realName, variable->realName );
89 cpu_inc_16bit( _environment, dataptr->realName );
90 cpu_inc_16bit( _environment, dataptr->realName );
91 break;
92 case 8:
93 cpu_inc_16bit( _environment, dataptr->realName );
94 cpu_move_8bit_indirect2( _environment, dataptr->realName, variable->realName );
95 cpu_inc_16bit( _environment, dataptr->realName );
96 break;
97 case 1:
99 break;
100 case 0:
101 switch( variable->type ) {
102 case VT_DSTRING: {
103 Variable * address = variable_temporary( _environment, VT_ADDRESS, "(address)" );
104 Variable * size = variable_temporary( _environment, VT_BYTE, "(size)" );
105 cpu_move_8bit_indirect2( _environment, dataptr->realName, size->realName );
106 cpu_inc_16bit( _environment, dataptr->realName );
107 cpu_dsfree( _environment, variable->realName );
108 cpu_dsalloc( _environment, size->realName, variable->realName );
109 cpu_dsdescriptor( _environment, variable->realName, address->realName, size->realName );
110 cpu_mem_move( _environment, dataptr->realName, address->realName, size->realName );
111 cpu_math_add_16bit_with_8bit( _environment, dataptr->realName, size->realName, dataptr->realName );
112 break;
113 }
114 case VT_TYPE: {
115 int os = VT_OPTIMAL_SHIFT( variable->typeType->size );
116 int bytes = 1 << os;
117 Variable * address = variable_temporary( _environment, VT_ADDRESS, "(address)" );
118 cpu_addressof_16bit( _environment, variable->realName, address->realName );
119 cpu_mem_move_size( _environment, dataptr->realName, address->realName, bytes );
120 cpu_math_add_16bit_const( _environment, dataptr->realName, bytes, dataptr->realName );
121 break;
122 }
123 default:
125 }
126 break;
127 }
128
129
130 }
131
132
133}
void cpu_move_32bit_indirect2(Environment *_environment, char *_value, char *_source)
Definition 6309.c:5398
void cpu_dsfree(Environment *_environment, char *_index)
Definition 6309.c:5917
void cpu_math_add_16bit_with_8bit(Environment *_environment, char *_source, char *_destination, char *_other)
Definition 6309.c:1708
void cpu_mem_move(Environment *_environment, char *_source, char *_destination, char *_size)
Definition 6309.c:4692
void cpu_addressof_16bit(Environment *_environment, char *_source, char *_destination)
Definition 6309.c:1485
void cpu_math_add_16bit_const(Environment *_environment, char *_source, int _destination, char *_other)
Definition 6309.c:1674
void cpu_move_16bit_indirect2(Environment *_environment, char *_value, char *_source)
Definition 6309.c:5352
void cpu_dsalloc(Environment *_environment, char *_size, char *_index)
Definition 6309.c:5895
void cpu_mem_move_size(Environment *_environment, char *_source, char *_destination, int _size)
Definition 6309.c:4781
void cpu_move_8bit_indirect2(Environment *_environment, char *_value, char *_source)
Definition 6309.c:5294
void cpu_inc_16bit(Environment *_environment, char *_variable)
Definition 6309.c:4565
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_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.
char * address_displacement(Environment *_environment, char *_address, char *_displacement)
int size
Definition _optimizer.c:678
void read_data_unsafe(Environment *_environment, char *_variable)
VariableType defaultVariableType
Definition ugbc.h:2956
int size
Definition ugbc.h:1245
VariableType type
Definition ugbc.h:988
struct _Type * typeType
Definition ugbc.h:1222
char * realName
Definition ugbc.h:982
#define CRITICAL_READ_DATA_TYPE_NOT_SUPPORTED(v, t)
Definition ugbc.h:3678
#define VT_OPTIMAL_SHIFT(s)
Definition ugbc.h:604
struct _Variable Variable
Structure of a single variable.
struct _Environment Environment
Structure of compilation environment.
@ VT_BYTE
Definition ugbc.h:450
@ VT_TYPE
Definition ugbc.h:546
@ VT_ADDRESS
Definition ugbc.h:465
@ VT_DSTRING
Definition ugbc.h:483
#define outline0(s)
Definition ugbc.h:4252
#define outline1(s, a)
Definition ugbc.h:4253
#define VT_BITWIDTH(t)
Definition ugbc.h:595
#define MAKE_LABEL
Definition ugbc.h:3351
char DATATYPE_AS_STRING[][16]