ugBASIC 1.18
An isomorphic BASIC language compiler for retrocomputers
Loading...
Searching...
No Matches
memcont.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
41/* <usermanual>
42@keyword MEMCONT
43
44@english
45
46The ''MEMCONT'' instruction uses ''param'' to specify how expansion memory
47will use registers. A value of 0 causes the registers for both sides of the
48transfer to automatically increment after each byte. The value 1 locks
49the expansion memory register, only the computer register continues to
50count (good for quickly deleting memory areas). The value 2 locks the computer address
51and only allows the expansion memory side to continue to count. The value 3 locks both sides
52of the transfer.
53
54@italian
55
56L'istruzione ''MEMCONT'' usa ''param'' per specificare come la memoria di espansione
57utilizzerà i registri. Un valore di 0 fa sì che i registri per entrambi i lati del
58trasferimento vengano automaticamente incrementati dopo ogni byte. Il valore 1 blocca
59il registro della memoria di espansione, solo il registro del computer continua a
60contare (utile per riempire rapidamente le aree di memoria). Il valore 2 blocca
61l'indirizzo del computer e consente solo al lato della memoria di espansione di
62continuare a contare. Il valore 3 blocca entrambi i lati del trasferimento.
63
64@syntax MEMCONT param
65
66@example MEMCONT 1
67
68@usedInExample tsb_memload.bas
69
70@seeAlso MEMLEN
71@seeAlso MEMPOS
72@seeAlso MEMCONT
73@seeAlso MEMRESTORE
74@seeAlso MEMLOAD
75@seeAlso MEMSAVE
76@seeAlso MEMDEF
77
78</usermanual> */
79
80void memcont( Environment * _environment, char * _param ) {
81
82 Variable * memcont = variable_retrieve_or_define( _environment, "MEMCONT", VT_BYTE, 0 );
83
84 Variable * param = variable_retrieve_or_define( _environment, _param, VT_BYTE, 0 );
85
86 variable_move( _environment, param->name, memcont->name );
87
88}
Variable * variable_retrieve_or_define(Environment *_environment, char *_name, VariableType _type, int _value)
Variable * variable_move(Environment *_environment, char *_source, char *_destination)
Store the value of a variable inside another variable by converting it.
void memcont(Environment *_environment, char *_param)
Definition memcont.c:80
char * name
Definition ugbc.h:979
struct _Variable Variable
Structure of a single variable.
struct _Environment Environment
Structure of compilation environment.
@ VT_BYTE
Definition ugbc.h:450