mirror of
https://github.com/tio/tio.git
synced 2026-05-01 23:07:58 +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
95 lines
2.9 KiB
C
95 lines
2.9 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 <string.h>
|
|
#include <sys/time.h>
|
|
#include <time.h>
|
|
#include "error.h"
|
|
#include "print.h"
|
|
#include "options.h"
|
|
#include "timestamp.h"
|
|
|
|
#define TIME_STRING_SIZE_MAX 24
|
|
|
|
char *timestamp_current_time(void)
|
|
{
|
|
static char time_string[TIME_STRING_SIZE_MAX];
|
|
static struct timeval tv, tv_now, tv_start, tv_previous;
|
|
static bool first = true;
|
|
struct tm *tm;
|
|
size_t len;
|
|
|
|
// Get current time value
|
|
gettimeofday(&tv_now, NULL);
|
|
|
|
if (first)
|
|
{
|
|
tv_start = tv_now;
|
|
first = false;
|
|
}
|
|
|
|
// Add formatted timestamp
|
|
switch (option.timestamp)
|
|
{
|
|
case TIMESTAMP_NONE:
|
|
case TIMESTAMP_24HOUR:
|
|
// "hh:mm:ss.sss" (24 hour format)
|
|
tv = tv_now;
|
|
tm = localtime(&tv.tv_sec);
|
|
len = strftime(time_string, sizeof(time_string), "%H:%M:%S", tm);
|
|
break;
|
|
case TIMESTAMP_24HOUR_START:
|
|
// "hh:mm:ss.sss" (24 hour format relative to start time)
|
|
timersub(&tv_now, &tv_start, &tv);
|
|
tm = gmtime(&tv.tv_sec);
|
|
len = strftime(time_string, sizeof(time_string), "%H:%M:%S", tm);
|
|
break;
|
|
case TIMESTAMP_24HOUR_DELTA:
|
|
// "hh:mm:ss.sss" (24 hour format relative to previous time stamp)
|
|
timersub(&tv_now, &tv_previous, &tv);
|
|
tm = gmtime(&tv.tv_sec);
|
|
len = strftime(time_string, sizeof(time_string), "%H:%M:%S", tm);
|
|
break;
|
|
case TIMESTAMP_ISO8601:
|
|
// "YYYY-MM-DDThh:mm:ss.sss" (ISO-8601)
|
|
tv = tv_now;
|
|
tm = localtime(&tv.tv_sec);
|
|
len = strftime(time_string, sizeof(time_string), "%Y-%m-%dT%H:%M:%S", tm);
|
|
break;
|
|
default:
|
|
return NULL;
|
|
}
|
|
|
|
// Append milliseconds to all timestamps
|
|
if (len)
|
|
{
|
|
len = snprintf(time_string + len, TIME_STRING_SIZE_MAX - len, ".%03ld", (long)tv.tv_usec / 1000);
|
|
}
|
|
|
|
// Save previous time value for next run
|
|
tv_previous = tv_now;
|
|
|
|
return (len < TIME_STRING_SIZE_MAX) ? time_string : NULL;
|
|
}
|