mirror of
https://github.com/tio/tio.git
synced 2026-05-01 14:57:59 +02:00
After including the use of glib we might as well replace inih with the glib key file parser. All configuraiton file parsing has been reworked and also the options parsing has been cleaned up, resulting in better and stricter configuration file and option value checks. Compared to old, configuration files now requires any default configurations to be put in a group/section named [default]. Configuration file keywords such as "enable", "disable", "on", "off", "yes", "no", "0", "1" have been retired. Now only "true" and "false" apply to boolean configuration options. This is done to simplify things and avoid any confusion. The pattern option feature has been reworked so now the user can now access the full match string and any matching subexpression using the %mN syntax. For example: [usb devices] pattern = usb([0-9]*) device = /dev/ttyUSB%m1 Then when using tio: $ tio usb12 %m0 = 'usb12' // Full match string %m1 = 12 // First match subexpression Which results in device = /dev/ttyUSB12
143 lines
3.1 KiB
C
143 lines
3.1 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 "config.h"
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <unistd.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();
|
|
|
|
/* 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 v%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();
|
|
}
|
|
|
|
/* 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;
|
|
}
|