mirror of
https://github.com/tio/tio.git
synced 2026-05-01 14:57:59 +02:00
Typing "@repl" after Ctrl-t r, enter Lua REPL mode.
Typing "@exit" in REPL mode will return you to normal mode.
Note:
- the determination of continuation lines is not done automatically, and
if the end of a line is \, it is determined to be a continuation
instruction.
- In REPL mode, tio's main loop is blocked. (Ctrl-t q works.)
Example:
>> t = {1,2,3,4,5}
>> for _,v in ipairs(t) do\
>> print(v,"\r")\
>> end
Implementation improvements:
- Add tty_init() and script_interp_init() in order to only once
initialization.
- Fix script function to work without device_fd.
155 lines
3.5 KiB
C
155 lines
3.5 KiB
C
/*
|
|
* tio - a serial device I/O tool
|
|
*
|
|
* Copyright (c) 2014-2022 Martin Lund
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
* 02110-1301, USA.
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <unistd.h>
|
|
#include "version.h"
|
|
#include "config.h"
|
|
#include "options.h"
|
|
#include "configfile.h"
|
|
#include "tty.h"
|
|
#include "log.h"
|
|
#include "error.h"
|
|
#include "print.h"
|
|
#include "signals.h"
|
|
#include "socket.h"
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
int status = 0;
|
|
|
|
/* Handle received signals */
|
|
signal_handlers_install();
|
|
|
|
/* Add error exit handler */
|
|
atexit(&error_exit);
|
|
|
|
/* Parse command-line options (1st pass) */
|
|
options_parse(argc, argv);
|
|
|
|
if (option.complete_profiles)
|
|
{
|
|
config_file_show_profiles();
|
|
return status;
|
|
}
|
|
|
|
/* Parse configuration file */
|
|
config_file_parse();
|
|
|
|
/* Parse command-line options (2nd pass) */
|
|
options_parse_final(argc, argv);
|
|
|
|
/* Configure tty device */
|
|
tty_configure();
|
|
|
|
/* Disable line buffering in stdout. This is necessary if we
|
|
* want things like local echo to work correctly. */
|
|
setvbuf(stdout, NULL, _IONBF, 0);
|
|
|
|
/* Configure input terminal */
|
|
if (isatty(fileno(stdin)))
|
|
{
|
|
stdin_configure();
|
|
}
|
|
else
|
|
{
|
|
// Enter non interactive mode
|
|
interactive_mode = false;
|
|
}
|
|
|
|
/* Switch error output format */
|
|
switch_error_output_mode();
|
|
|
|
/* Configure output terminal */
|
|
if (isatty(fileno(stdout)))
|
|
{
|
|
stdout_configure();
|
|
}
|
|
else
|
|
{
|
|
// No color when piping
|
|
option.color = -1;
|
|
}
|
|
|
|
/* Add log exit handler */
|
|
atexit(&log_exit);
|
|
|
|
/* Create log file */
|
|
if (option.log)
|
|
{
|
|
log_open(option.log_filename);
|
|
}
|
|
|
|
/* Initialize ANSI text formatting (colors etc.) */
|
|
print_init_ansi_formatting();
|
|
|
|
/* Change error printing mode */
|
|
error_enter_session_mode();
|
|
|
|
/* Print launch hints */
|
|
tio_printf("tio %s", VERSION);
|
|
if (interactive_mode)
|
|
{
|
|
tio_printf("Press ctrl-%c q to quit", option.prefix_key);
|
|
}
|
|
else
|
|
{
|
|
tio_printf("Non-interactive mode enabled");
|
|
tio_printf("Press ctrl-c to quit");
|
|
}
|
|
|
|
/* Open socket */
|
|
if (option.socket)
|
|
{
|
|
socket_configure();
|
|
}
|
|
|
|
/* Script interpreter init */
|
|
script_interp_init();
|
|
|
|
/* Initialize tty module once on program start */
|
|
tty_init();
|
|
|
|
/* Spawn input handling into separate thread */
|
|
tty_input_thread_create();
|
|
|
|
/* Wait for input to be ready */
|
|
tty_input_thread_wait_ready();
|
|
|
|
/* Connect to tty device */
|
|
if (option.no_reconnect)
|
|
{
|
|
tty_search();
|
|
status = tty_connect();
|
|
}
|
|
else
|
|
{
|
|
/* Enter connect loop */
|
|
while (true)
|
|
{
|
|
tty_wait_for_device();
|
|
tty_connect();
|
|
}
|
|
}
|
|
|
|
return status;
|
|
}
|