mirror of
https://github.com/dkogan/feedgnuplot.git
synced 2025-09-18 19:18:06 +08:00
Compare commits
2 Commits
v1.50
...
test_strpt
Author | SHA1 | Date | |
---|---|---|---|
![]() |
8ae16172ef | ||
![]() |
11f568ddf2 |
@@ -14,7 +14,7 @@ use threads;
|
|||||||
use threads::shared;
|
use threads::shared;
|
||||||
use Thread::Queue;
|
use Thread::Queue;
|
||||||
use Pod::Usage;
|
use Pod::Usage;
|
||||||
use Time::Piece;
|
use DateTime::Format::Strptime;
|
||||||
|
|
||||||
my $VERSION = 1.34;
|
my $VERSION = 1.34;
|
||||||
|
|
||||||
@@ -31,6 +31,9 @@ interpretCommandline();
|
|||||||
# datastring
|
# datastring
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
my $strptime;
|
||||||
|
|
||||||
my @curves = ();
|
my @curves = ();
|
||||||
|
|
||||||
# list mapping curve names to their indices in the @curves list
|
# list mapping curve names to their indices in the @curves list
|
||||||
@@ -382,12 +385,16 @@ sub interpretCommandline
|
|||||||
# and strftime, and those are integer-only
|
# and strftime, and those are integer-only
|
||||||
if( defined $options{xlen} )
|
if( defined $options{xlen} )
|
||||||
{
|
{
|
||||||
|
# warning do I need to make sure this is an integer anymore?
|
||||||
if( $options{xlen} - int($options{xlen}) )
|
if( $options{xlen} - int($options{xlen}) )
|
||||||
{
|
{
|
||||||
print STDERR "When streaming --xlen MUST be an integer. Rounding up to the nearest second\n";
|
print STDERR "When streaming --xlen MUST be an integer. Rounding up to the nearest second\n";
|
||||||
$options{xlen} = 1 + int($options{xlen});
|
$options{xlen} = 1 + int($options{xlen});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# $strptime = DateTime::Format::Strptime->new( pattern => $options{timefmt} );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -440,14 +447,18 @@ sub makeDomainNumeric
|
|||||||
{
|
{
|
||||||
my ($domain0) = @_;
|
my ($domain0) = @_;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if( $options{timefmt})
|
if( $options{timefmt})
|
||||||
{
|
{
|
||||||
my $timepiece = Time::Piece->strptime( $domain0, $options{timefmt} )
|
# my $t = $strptime->parse_datetime($domain0);
|
||||||
or die "Couldn't parse time format. String '$domain0' doesn't fit format '$options{timefmt}'";
|
# print STDERR "$domain0 $t\n";
|
||||||
|
|
||||||
return $timepiece->epoch();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# return $strptime->parse_datetime($domain0) if $options{timefmt};
|
||||||
return $domain0;
|
return $domain0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -692,6 +703,17 @@ sub mainThread
|
|||||||
@domain = splice(@fields, 0, 2);
|
@domain = splice(@fields, 0, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# domain0_numeric is only used for xlen and monotonic, I think. And
|
||||||
|
# this is the only thing that requires strptime. Shouldn't bother with
|
||||||
|
# strptime otherwise
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if( $options{monotonic} )
|
if( $options{monotonic} )
|
||||||
{
|
{
|
||||||
if( defined $latestX && $domain0_numeric < $latestX )
|
if( defined $latestX && $domain0_numeric < $latestX )
|
||||||
@@ -751,14 +773,8 @@ sub mainThread
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# if we were streaming, we're now done!
|
|
||||||
if( $options{stream} )
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
# finished reading in all. Plot what we have
|
# finished reading in all. Plot what we have
|
||||||
plotStoredData();
|
plotStoredData() unless $options{stream};
|
||||||
|
|
||||||
if ( defined $options{hardcopy})
|
if ( defined $options{hardcopy})
|
||||||
{
|
{
|
||||||
@@ -1002,7 +1018,7 @@ sub replot
|
|||||||
{
|
{
|
||||||
# if we're using a timefmt, I need to convert my xmin range from
|
# if we're using a timefmt, I need to convert my xmin range from
|
||||||
# seconds-since-the-epoch BACK to the timefmt. Sheesh
|
# seconds-since-the-epoch BACK to the timefmt. Sheesh
|
||||||
($xmin, $xmax) = map {Time::Piece->strptime( $_, '%s' )->strftime( $options{timefmt} ) } ($xmin, $xmax);
|
($xmin, $xmax) = map {$strptime->parse_datetime($_)} ($xmin, $xmax);
|
||||||
}
|
}
|
||||||
sendRangeCommand( "xrange", $xmin, $xmax );
|
sendRangeCommand( "xrange", $xmin, $xmax );
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user