mirror of
https://github.com/dkogan/feedgnuplot.git
synced 2025-05-06 06:21:16 +08:00
Merge branch 'master' into debian
This commit is contained in:
commit
3c14e4e106
6
Changes
6
Changes
@ -1,3 +1,9 @@
|
|||||||
|
feedgnuplot (1.53)
|
||||||
|
|
||||||
|
* Full support for all 4 axes. Added --x2...
|
||||||
|
|
||||||
|
-- Dima Kogan <dkogan@debian.org> Wed, 08 Jan 2020 18:55:29 -0800
|
||||||
|
|
||||||
feedgnuplot (1.52)
|
feedgnuplot (1.52)
|
||||||
|
|
||||||
* Added --squarexy and --square-xy as synonyms to --square_xy
|
* Added --squarexy and --square-xy as synonyms to --square_xy
|
||||||
|
@ -16,7 +16,7 @@ use Pod::Usage;
|
|||||||
use Time::Piece;
|
use Time::Piece;
|
||||||
|
|
||||||
# Makefile.PL assumes this is in ''
|
# Makefile.PL assumes this is in ''
|
||||||
my $VERSION = '1.52';
|
my $VERSION = '1.53';
|
||||||
|
|
||||||
my %options;
|
my %options;
|
||||||
interpretCommandline();
|
interpretCommandline();
|
||||||
@ -91,7 +91,9 @@ sub interpretCommandline
|
|||||||
$options{curvestyle} = [];
|
$options{curvestyle} = [];
|
||||||
$options{style} = [];
|
$options{style} = [];
|
||||||
$options{histogram} = [];
|
$options{histogram} = [];
|
||||||
$options{y2} = [];
|
$options{x1y2} = [];
|
||||||
|
$options{x2y1} = [];
|
||||||
|
$options{x2y2} = [];
|
||||||
$options{extracmds} = [];
|
$options{extracmds} = [];
|
||||||
$options{set} = [];
|
$options{set} = [];
|
||||||
$options{unset} = [];
|
$options{unset} = [];
|
||||||
@ -105,9 +107,12 @@ sub interpretCommandline
|
|||||||
$options{tuplesize} = [];
|
$options{tuplesize} = [];
|
||||||
|
|
||||||
GetOptions(\%options, 'stream:s', 'domain!', 'dataid!', 'vnlog!', '3d!', 'colormap!', 'lines!', 'points!',
|
GetOptions(\%options, 'stream:s', 'domain!', 'dataid!', 'vnlog!', '3d!', 'colormap!', 'lines!', 'points!',
|
||||||
'circles', 'legend=s{2}', 'autolegend!', 'xlabel=s', 'ylabel=s', 'y2label=s', 'zlabel=s',
|
'circles', 'legend=s{2}', 'autolegend!', 'xlabel=s', 'x2label=s', 'ylabel=s', 'y2label=s', 'zlabel=s',
|
||||||
'title=s', 'xlen=f', 'ymin=f', 'ymax=f', 'xmin=s', 'xmax=s', 'y2min=f', 'y2max=f',
|
'title=s', 'xlen=f',
|
||||||
'zmin=f', 'zmax=f', 'y2=s@',
|
'xmin=s', 'xmax=s', 'x2min=s', 'x2max=s',
|
||||||
|
'ymin=f', 'ymax=f', 'y2min=f', 'y2max=f',
|
||||||
|
'zmin=f', 'zmax=f',
|
||||||
|
'x2=s@', 'y2=s@', 'x1y2=s@', 'x2y1=s@', 'x2y2=s@',
|
||||||
'style=s{2}', 'curvestyle=s{2}', 'curvestyleall=s', 'styleall=s', 'with=s', 'extracmds=s@', 'set=s@', 'unset=s@',
|
'style=s{2}', 'curvestyle=s{2}', 'curvestyleall=s', 'styleall=s', 'with=s', 'extracmds=s@', 'set=s@', 'unset=s@',
|
||||||
'square!', 'square_xy!', 'square-xy!', 'squarexy!', 'hardcopy=s', 'maxcurves=i', 'monotonic!', 'timefmt=s',
|
'square!', 'square_xy!', 'square-xy!', 'squarexy!', 'hardcopy=s', 'maxcurves=i', 'monotonic!', 'timefmt=s',
|
||||||
'equation=s@',
|
'equation=s@',
|
||||||
@ -168,7 +173,7 @@ sub interpretCommandline
|
|||||||
}
|
}
|
||||||
|
|
||||||
# expand options that are given as comma-separated lists
|
# expand options that are given as comma-separated lists
|
||||||
for my $listkey (qw(histogram y2))
|
for my $listkey (qw(histogram x2 y2 x1y2 x2y1 x2y2))
|
||||||
{
|
{
|
||||||
@{$options{$listkey}} = map split('\s*,\s*', $_), @{$options{$listkey}}
|
@{$options{$listkey}} = map split('\s*,\s*', $_), @{$options{$listkey}}
|
||||||
if defined $options{$listkey};
|
if defined $options{$listkey};
|
||||||
@ -192,6 +197,11 @@ sub interpretCommandline
|
|||||||
@{$options{$listkey}} = @out;
|
@{$options{$listkey}} = @out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# handle x2 == x2y1 and y2 == x1y2
|
||||||
|
push @{$options{x2y1}}, @{$options{x2}} if defined $options{x2};
|
||||||
|
push @{$options{x1y2}}, @{$options{y2}} if defined $options{y2};
|
||||||
|
$options{x2} = [];
|
||||||
|
$options{y2} = [];
|
||||||
|
|
||||||
# convert all tuplesize business to rangesize
|
# convert all tuplesize business to rangesize
|
||||||
my $domainsize = $options{'3d'} ? 2 : 1;
|
my $domainsize = $options{'3d'} ? 2 : 1;
|
||||||
@ -351,9 +361,11 @@ sub interpretCommandline
|
|||||||
exit -1;
|
exit -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( defined $options{y2min} || defined $options{y2max} || @{$options{y2}} )
|
if ( defined $options{x2min} || defined $options{x2max} ||
|
||||||
|
defined $options{y2min} || defined $options{y2max} ||
|
||||||
|
@{$options{x1y2}} || @{$options{x2y1}} || @{$options{x2y2}} )
|
||||||
{
|
{
|
||||||
print STDERR "--3d does not make sense with --y2...\n";
|
print STDERR "--3d does not make sense with --x2... or --y2...\n";
|
||||||
exit -1;
|
exit -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -749,9 +761,10 @@ sub mainThread
|
|||||||
print PIPE "set grid\n";
|
print PIPE "set grid\n";
|
||||||
|
|
||||||
print(PIPE "set xlabel \"$options{xlabel }\"\n") if defined $options{xlabel};
|
print(PIPE "set xlabel \"$options{xlabel }\"\n") if defined $options{xlabel};
|
||||||
|
print(PIPE "set x2label \"$options{x2label}\"\n") if defined $options{x2label};
|
||||||
print(PIPE "set ylabel \"$options{ylabel }\"\n") if defined $options{ylabel};
|
print(PIPE "set ylabel \"$options{ylabel }\"\n") if defined $options{ylabel};
|
||||||
print(PIPE "set zlabel \"$options{zlabel }\"\n") if defined $options{zlabel};
|
|
||||||
print(PIPE "set y2label \"$options{y2label}\"\n") if defined $options{y2label};
|
print(PIPE "set y2label \"$options{y2label}\"\n") if defined $options{y2label};
|
||||||
|
print(PIPE "set zlabel \"$options{zlabel }\"\n") if defined $options{zlabel};
|
||||||
print(PIPE "set title \"$options{title }\"\n") if defined $options{title};
|
print(PIPE "set title \"$options{title }\"\n") if defined $options{title};
|
||||||
|
|
||||||
if($options{square})
|
if($options{square})
|
||||||
@ -800,8 +813,9 @@ sub mainThread
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# For the values requested to be printed on the y2 axis, set that
|
addCurveOption($_, 'axes x1y2') foreach (@{$options{x1y2}});
|
||||||
addCurveOption($_, 'axes x1y2') foreach (@{$options{y2}});
|
addCurveOption($_, 'axes x2y1') foreach (@{$options{x2y1}});
|
||||||
|
addCurveOption($_, 'axes x2y2') foreach (@{$options{x2y2}});
|
||||||
|
|
||||||
# timefmt
|
# timefmt
|
||||||
if( $options{timefmt} )
|
if( $options{timefmt} )
|
||||||
@ -818,7 +832,14 @@ sub mainThread
|
|||||||
|
|
||||||
setCurveAsHistogram( $_ ) foreach (@{$options{histogram}});
|
setCurveAsHistogram( $_ ) foreach (@{$options{histogram}});
|
||||||
|
|
||||||
if(@{$options{y2}})
|
if(@{$options{x2y1}} || @{$options{x2y2}})
|
||||||
|
{
|
||||||
|
print PIPE "set xtics nomirror\n";
|
||||||
|
print PIPE "set x2tics\n";
|
||||||
|
# if any of the ranges are given, set the range
|
||||||
|
sendRangeCommand( "x2range", $options{x2min}, $options{x2max} );
|
||||||
|
}
|
||||||
|
if(@{$options{x1y2}} || @{$options{x2y2}})
|
||||||
{
|
{
|
||||||
print PIPE "set ytics nomirror\n";
|
print PIPE "set ytics nomirror\n";
|
||||||
print PIPE "set y2tics\n";
|
print PIPE "set y2tics\n";
|
||||||
@ -1369,6 +1390,7 @@ Simple plotting of piped data:
|
|||||||
2 +-----------------------------------------------------------------+ 0
|
2 +-----------------------------------------------------------------+ 0
|
||||||
1 1.5 2 2.5 3 3.5 4 4.5 5
|
1 1.5 2 2.5 3 3.5 4 4.5 5
|
||||||
|
|
||||||
|
Here we asked for ASCII plotting, which is useful for documentation.
|
||||||
|
|
||||||
Simple real-time plotting example: plot how much data is received on the wlan0
|
Simple real-time plotting example: plot how much data is received on the wlan0
|
||||||
network interface in bytes/second (uses bash, awk and Linux):
|
network interface in bytes/second (uses bash, awk and Linux):
|
||||||
@ -1831,10 +1853,10 @@ plot I<only> histograms or I<only> I<non>-histograms.
|
|||||||
|
|
||||||
=item
|
=item
|
||||||
|
|
||||||
C<--xmin/xmax/ymin/ymax/y2min/y2max/zmin/zmax xxx>
|
C<--xmin/xmax/x2min/x2max/ymin/ymax/y2min/y2max/zmin/zmax xxx>
|
||||||
|
|
||||||
Set the range for the given axis. These x-axis bounds are ignored in a streaming
|
Set the range for the given axis. These x-axis bounds are ignored in a streaming
|
||||||
plot. The y2-axis bound do not apply in 3d plots. The z-axis bounds apply
|
plot. The x2/y2-axis bounds do not apply in 3d plots. The z-axis bounds apply
|
||||||
I<only> to 3d plots or colormaps. Note that there is no C<--xrange> to set both
|
I<only> to 3d plots or colormaps. Note that there is no C<--xrange> to set both
|
||||||
sides at once or C<--xinv> to flip the axis around: anything more than the
|
sides at once or C<--xinv> to flip the axis around: anything more than the
|
||||||
basics supported in this option is clearly obtainable by talking to gnuplot, for
|
basics supported in this option is clearly obtainable by talking to gnuplot, for
|
||||||
@ -1842,23 +1864,29 @@ instance C<--set 'xrange [20:10]'> to set the given inverted bounds.
|
|||||||
|
|
||||||
=item
|
=item
|
||||||
|
|
||||||
C<--xlabel/ylabel/y2label/zlabel xxx>
|
C<--xlabel/x2label/ylabel/y2label/zlabel xxx>
|
||||||
|
|
||||||
Label the given axis. The y2-axis label does not apply to 3d plots while the
|
Label the given axis. The x2/y2-axis labels do not apply to 3d plots while the
|
||||||
z-axis label applies I<only> to 3d plots.
|
z-axis label applies I<only> to 3d plots.
|
||||||
|
|
||||||
=item
|
=item
|
||||||
|
|
||||||
C<--y2 xxx>
|
C<--x2/--y2/--x1y2/--x2y1/--x2y2 xxx>
|
||||||
|
|
||||||
Plot the data specified by this curve ID on the y2 axis. Without C<--dataid>,
|
By default data is plotted against the x1 and y1 axes (the left and bottom one
|
||||||
the ID is just an ordered 0-based index. Does not apply to 3d plots. Can be
|
respectively). If we want a particular curve plotted against a different axis,
|
||||||
passed multiple times, or passed a comma-separated list. By default the y2-axis
|
we can specify that with these options. You pass C<--AXIS ID> where C<AXIS>
|
||||||
curves look the same as the y-axis ones. I.e. the viewer of the resulting plot
|
defines the axis (C<x2> or C<y2> or C<x1y2> or C<x2y1> or C<x2y2>) and the C<ID>
|
||||||
has to be told which is which via an axes label, legend, etc. Prior to version
|
is the curve ID. C<--x2> is a synonym for C<--x2y1> and C<--y2> is a synonym for
|
||||||
1.25 of feedgnuplot the curves plotted on the y2 axis were drawn with a thicker
|
C<--x1y2>. The curve ID is an ordered 0-based index or a specific ID if
|
||||||
line. This is no longer the case, but that behavior can be brought back by
|
C<--dataid> or C<--vnlog>. None of these apply to 3d plots. Can be passed
|
||||||
passing something like
|
multiple times for different curve IDs, multiple IDs can be passed in as a
|
||||||
|
comma-separated list. By default the curves plotted against the various axes
|
||||||
|
aren not drawn in any differentiated way: the viewer of the resulting plot has
|
||||||
|
to be told which is which via an axes label, legend, colors, etc. Prior to
|
||||||
|
version 1.25 of C<feedgnuplot> the curves plotted on the y2 axis were drawn with
|
||||||
|
a thicker line. This is no longer the case, but that behavior can be brought
|
||||||
|
back by passing something like
|
||||||
|
|
||||||
--y2 curveid --style curveid 'linewidth 3'
|
--y2 curveid --style curveid 'linewidth 3'
|
||||||
|
|
||||||
|
@ -17,6 +17,8 @@ complete -W \
|
|||||||
--extraValuesPerPoint \
|
--extraValuesPerPoint \
|
||||||
--rangesizeall \
|
--rangesizeall \
|
||||||
--rangesize \
|
--rangesize \
|
||||||
|
--tuplesizeall \
|
||||||
|
--tuplesize \
|
||||||
--extracmds \
|
--extracmds \
|
||||||
--set \
|
--set \
|
||||||
--unset \
|
--unset \
|
||||||
@ -39,17 +41,25 @@ complete -W \
|
|||||||
--timefmt \
|
--timefmt \
|
||||||
--title \
|
--title \
|
||||||
--version \
|
--version \
|
||||||
|
--x2 \
|
||||||
|
--y2 \
|
||||||
|
--x2y1 \
|
||||||
|
--x1y2 \
|
||||||
|
--x2y2 \
|
||||||
--xlabel \
|
--xlabel \
|
||||||
--xlen \
|
--xlen \
|
||||||
--xmax \
|
--xmax \
|
||||||
--xmin \
|
--xmin \
|
||||||
--y2 \
|
--x2label \
|
||||||
--y2label \
|
--x2max \
|
||||||
--y2max \
|
--x2min \
|
||||||
--y2min \
|
|
||||||
--ylabel \
|
--ylabel \
|
||||||
--ymax \
|
--ymax \
|
||||||
--ymin \
|
--ymin \
|
||||||
|
--y2label \
|
||||||
|
--y2max \
|
||||||
|
--y2min \
|
||||||
--zlabel \
|
--zlabel \
|
||||||
--zmax \
|
--zmax \
|
||||||
--zmin' feedgnuplot
|
--zmin \
|
||||||
|
--vnlog ' feedgnuplot
|
||||||
|
@ -10,22 +10,28 @@ _arguments -S
|
|||||||
'--points' \
|
'--points' \
|
||||||
'--circles' \
|
'--circles' \
|
||||||
'--xlabel:X-axis label:' \
|
'--xlabel:X-axis label:' \
|
||||||
|
'--x2label:X2-axis label:' \
|
||||||
'--ylabel:Y-axis label:' \
|
'--ylabel:Y-axis label:' \
|
||||||
'--y2label:Y2-axis label:' \
|
'--y2label:Y2-axis label:' \
|
||||||
'--zlabel:Z-axis label:' \
|
'--zlabel:Z-axis label:' \
|
||||||
'--zlabel:Z-axis label:' \
|
|
||||||
'--title:Plot title:' \
|
'--title:Plot title:' \
|
||||||
'--autolegend[Label each plot with its data ID]' \
|
'--autolegend[Label each plot with its data ID]' \
|
||||||
'(--3d)--xlen[the size of the x-window to plot]:window size:' \
|
'(--3d)--xlen[the size of the x-window to plot]:window size:' \
|
||||||
'(--xlen)--xmin:min X:' \
|
'(--xlen)--xmin:min X:' \
|
||||||
'(--xlen)--xmax:max X:' \
|
'(--xlen)--xmax:max X:' \
|
||||||
|
'--x2min:min X2:' \
|
||||||
|
'--x2max:max X2:' \
|
||||||
'--ymin:min Y:' \
|
'--ymin:min Y:' \
|
||||||
'--ymax:max Y:' \
|
'--ymax:max Y:' \
|
||||||
'--y2min:min Y2:' \
|
'--y2min:min Y2:' \
|
||||||
'--y2max:max Y2:' \
|
'--y2max:max Y2:' \
|
||||||
'--zmin:min Z:' \
|
'--zmin:min Z:' \
|
||||||
'--zmax:max Z:' \
|
'--zmax:max Z:' \
|
||||||
'*--y2:plot to place on the Y2 axis:' \
|
'*--x2:curve to place on the X2Y1 axis:' \
|
||||||
|
'*--y2:curve to place on the X1Y2 axis:' \
|
||||||
|
'*--x2y1:curve to place on the X2Y1 axis:' \
|
||||||
|
'*--x1y2:curve to place on the X1Y2 axis:' \
|
||||||
|
'*--x2y2:curve to place on the X2Y2 axis:' \
|
||||||
'(--with)--curvestyleall[Additional styles for ALL curves]:style' \
|
'(--with)--curvestyleall[Additional styles for ALL curves]:style' \
|
||||||
'(--with)--styleall[Additional styles for ALL curves]:style' \
|
'(--with)--styleall[Additional styles for ALL curves]:style' \
|
||||||
'(--curvestyleall)--with[Additional styles for ALL curves]:style' \
|
'(--curvestyleall)--with[Additional styles for ALL curves]:style' \
|
||||||
@ -42,6 +48,8 @@ _arguments -S
|
|||||||
'(--rangesizeall)--extraValuesPerPoint[How many extra values are given for each data range]:N'\
|
'(--rangesizeall)--extraValuesPerPoint[How many extra values are given for each data range]:N'\
|
||||||
'(--extraValuesPerPoint)--rangesizeall[How many values are given for each data range]:N'\
|
'(--extraValuesPerPoint)--rangesizeall[How many values are given for each data range]:N'\
|
||||||
'*--rangesize[How many values comprise a data range in this curve]:curve id: :N:' \
|
'*--rangesize[How many values comprise a data range in this curve]:curve id: :N:' \
|
||||||
|
'(--extraValuesPerPoint)--tuplesizeall[How many values are given for each data tuple]:N'\
|
||||||
|
'*--tuplesize[How many values comprise a data tuple in this curve]:curve id: :N:' \
|
||||||
'--dump[Instead of printing to gnuplot, print to STDOUT]' \
|
'--dump[Instead of printing to gnuplot, print to STDOUT]' \
|
||||||
'--geometry[The X11 geometry string]:geometry string:' \
|
'--geometry[The X11 geometry string]:geometry string:' \
|
||||||
'*--curvestyle[Additional styles for a curve]:curve id: :style:' \
|
'*--curvestyle[Additional styles for a curve]:curve id: :style:' \
|
||||||
@ -54,4 +62,5 @@ _arguments -S
|
|||||||
'--exit[Exit gnuplot after making the plot]' \
|
'--exit[Exit gnuplot after making the plot]' \
|
||||||
'--version' \
|
'--version' \
|
||||||
'--help' \
|
'--help' \
|
||||||
'--timefmt[Format for time/date data]:time format'
|
'--timefmt[Format for time/date data]:time format' \
|
||||||
|
'--vnlog[column IDs come from a vnlog header]'
|
||||||
|
Loading…
Reference in New Issue
Block a user