ugBASIC 1.18
An isomorphic BASIC language compiler for retrocomputers
Loading...
Searching...
No Matches
fujinet_open.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 FUJINET OPEN
43
44@english
45
46The ''OPEN'' instruction allows you to open a connection to the selected device.
47The ''url'' parameter must contain the device specification, in the format
48''N:PROTO://[HOSTNAME]:PORT/PATH/.../''. The mode parameter, if indicated,
49specifies the mode according to the FujiNet standard (''4''=read, ''8''=write,
50''12''=read/write, ''13''=POST, and so on). The trans parameter indicates the
51translation mode of the so-called "end of line" to be applied to incoming data
52(''0'=none, ''1''=CR, ''2''=LF, ''3''=CRLF, ''4''=Pet). This command can also
53be used as a function, to obtain the error code, if of interest.
54
55@italian
56
57Questa istruzione permette di aprire una connessione sulla periferica selezionata.
58Il paralmetro ''url'' dovrà contenere la specifica del dispositivo, nel formato
59''N:PROTO://[HOSTNAME]:PORT/PATH/.../''. Il parametro mode, se indicato, specifica
60la modalità secondo lo standard FujiNet (''4''=lettura, ''8''=scrittura,
61''12''=lettura/scrittura, ''13''=POST, e così via). Il parametro ''trans'' indica
62la modalità di traduzione dei cosiddetti "fine linea" da applicare ai dati in arrivo
63(''0''=nessuna, ''1''=CR, ''2''=LF, ''3''=CRLF, ''4''=Pet). Questo comando può essere
64usato anche come una funzione, per ottenere l'eventuale codice di errore, se di interesse.
65
66@syntax FUJINET OPEN url, mode , trans
67@syntax = FUJINET OPEN ( url, mode , trans )
68
69@example IF FUJINET OPEN ( "telnet://localhost", 4, 0 ) THEN: PRINT "Opened!": ENDIF
70
71@target coco
72</usermanual> */
73
74#if !defined(__atari__) && !defined(__atarixl__) && !defined(__coco__) && !defined(__cocob__)
75
76Variable * fujinet_open( Environment * _environment, char * _url, char * _mode, char * _trans ) {
77
78 Variable * result = variable_temporary( _environment, VT_BYTE, "(result)" );
79
80 return result;
81
82}
83
84#endif
Variable * variable_temporary(Environment *_environment, VariableType _type, char *_meaning)
Define a temporary variable.
Variable * fujinet_open(Environment *_environment, char *_url, char *_mode, char *_trans)
struct _Variable Variable
Structure of a single variable.
struct _Environment Environment
Structure of compilation environment.
@ VT_BYTE
Definition ugbc.h:450