annotate src/pt-plot.cc @ 3180:c17387059fd3

[project @ 1998-09-24 18:59:11 by jwe]
author jwe
date Thu, 24 Sep 1998 19:00:19 +0000
parents e4bbfc196e53
children bef7b73c0724
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1 /*
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2
2847
8b262e771614 [project @ 1997-03-27 16:18:26 by jwe]
jwe
parents: 2800
diff changeset
3 Copyright (C) 1996, 1997 John W. Eaton
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
4
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
5 This file is part of Octave.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
7 Octave is free software; you can redistribute it and/or modify it
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
9 Free Software Foundation; either version 2, or (at your option) any
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
10 later version.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
11
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
12 Octave is distributed in the hope that it will be useful, but WITHOUT
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
15 for more details.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
16
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
18 along with Octave; see the file COPYING. If not, write to the Free
1315
611d403c7f3d [project @ 1995-06-25 19:56:32 by jwe]
jwe
parents: 1297
diff changeset
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
20
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
21 */
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
22
1297
12ecc2ecf0e3 [project @ 1995-05-01 18:39:43 by jwe]
jwe
parents: 1203
diff changeset
23 #if defined (__GNUG__)
12ecc2ecf0e3 [project @ 1995-05-01 18:39:43 by jwe]
jwe
parents: 1203
diff changeset
24 #pragma implementation
12ecc2ecf0e3 [project @ 1995-05-01 18:39:43 by jwe]
jwe
parents: 1203
diff changeset
25 #endif
12ecc2ecf0e3 [project @ 1995-05-01 18:39:43 by jwe]
jwe
parents: 1203
diff changeset
26
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 191
diff changeset
27 #ifdef HAVE_CONFIG_H
1192
b6360f2d4fa6 [project @ 1995-03-30 21:38:35 by jwe]
jwe
parents: 1086
diff changeset
28 #include <config.h>
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
29 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
30
1343
94bedeb289e5 [project @ 1995-09-04 00:29:21 by jwe]
jwe
parents: 1328
diff changeset
31 #include <cstring>
94bedeb289e5 [project @ 1995-09-04 00:29:21 by jwe]
jwe
parents: 1328
diff changeset
32
1728
42b4f904f1af [project @ 1996-01-09 11:36:01 by jwe]
jwe
parents: 1690
diff changeset
33 #include <string>
42b4f904f1af [project @ 1996-01-09 11:36:01 by jwe]
jwe
parents: 1690
diff changeset
34
1350
5f63d83dd694 [project @ 1995-09-05 07:37:59 by jwe]
jwe
parents: 1343
diff changeset
35 #include <fstream.h>
5f63d83dd694 [project @ 1995-09-05 07:37:59 by jwe]
jwe
parents: 1343
diff changeset
36 #include <iostream.h>
5f63d83dd694 [project @ 1995-09-05 07:37:59 by jwe]
jwe
parents: 1343
diff changeset
37 #include <strstream.h>
5f63d83dd694 [project @ 1995-09-05 07:37:59 by jwe]
jwe
parents: 1343
diff changeset
38
5f63d83dd694 [project @ 1995-09-05 07:37:59 by jwe]
jwe
parents: 1343
diff changeset
39 #ifdef HAVE_UNISTD_H
2442
f667d7ec08b9 [project @ 1996-10-30 18:46:22 by jwe]
jwe
parents: 2371
diff changeset
40 #ifdef HAVE_SYS_TYPES_H
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
41 #include <sys/types.h>
2442
f667d7ec08b9 [project @ 1996-10-30 18:46:22 by jwe]
jwe
parents: 2371
diff changeset
42 #endif
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
43 #include <unistd.h>
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
44 #endif
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
45
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
46 #include "SLStack.h"
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
47 #include "procstream.h"
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
48
1802
8173b1fa052d [project @ 1996-01-29 06:10:18 by jwe]
jwe
parents: 1755
diff changeset
49 #include "file-ops.h"
2891
1a30f46e1870 [project @ 1997-04-28 01:49:00 by jwe]
jwe
parents: 2859
diff changeset
50 #include "lo-mappers.h"
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
51 #include "str-vec.h"
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
52
1352
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1350
diff changeset
53 #include "defun.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1350
diff changeset
54 #include "error.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1350
diff changeset
55 #include "gripes.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1350
diff changeset
56 #include "load-save.h"
1742
a02f140ed897 [project @ 1996-01-12 11:09:39 by jwe]
jwe
parents: 1728
diff changeset
57 #include "oct-obj.h"
a02f140ed897 [project @ 1996-01-12 11:09:39 by jwe]
jwe
parents: 1728
diff changeset
58 #include "pt-cmd.h"
a02f140ed897 [project @ 1996-01-12 11:09:39 by jwe]
jwe
parents: 1728
diff changeset
59 #include "pt-exp.h"
a02f140ed897 [project @ 1996-01-12 11:09:39 by jwe]
jwe
parents: 1728
diff changeset
60 #include "pt-plot.h"
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
61 #include "pt-walk.h"
2209
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
62 #include "sighandlers.h"
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
63 #include "sysdep.h"
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
64 #include "utils.h"
2371
dd29ab8af9e7 [project @ 1996-10-12 00:09:55 by jwe]
jwe
parents: 2305
diff changeset
65 #include "variables.h"
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
66
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
67 // If TRUE, a replot command is issued automatically each time a plot
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
68 // changes in some way.
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
69 static bool Vautomatic_replot;
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
70
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
71 // The name of the shell command to execute to start gnuplot.
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
72 static string Vgnuplot_binary;
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
73
2289
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
74 // TRUE if gnuplot appears to support multiple plot windows with X11.
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
75 static bool Vgnuplot_has_frames;
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
76
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
77 // TRUE if gnuplot appears to support multiplot.
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
78 static bool Vgnuplot_has_multiplot;
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
79
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
80 // The number of lines we've plotted so far.
735
7455048010b9 [project @ 1994-09-24 03:22:34 by jwe]
jwe
parents: 662
diff changeset
81 static int plot_line_count = 0;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
82
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
83 // Is this a parametric plot? Makes a difference for 3D plotting.
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
84 static bool parametric_plot = false;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
85
943
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
86 // The gnuplot terminal type.
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
87 static char *gnuplot_terminal_type = 0;
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
88
478
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
89 // Should the graph window be cleared before plotting the next line?
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
90 static bool clear_before_plotting = true;
478
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
91
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
92 // List of files to delete when we exit or crash.
2614
ae47b0911863 [project @ 1997-01-21 03:57:46 by jwe]
jwe
parents: 2586
diff changeset
93 //
ae47b0911863 [project @ 1997-01-21 03:57:46 by jwe]
jwe
parents: 2586
diff changeset
94 // XXX FIXME XXX -- this should really be static, but that causes
ae47b0911863 [project @ 1997-01-21 03:57:46 by jwe]
jwe
parents: 2586
diff changeset
95 // problems on some systems.
ae47b0911863 [project @ 1997-01-21 03:57:46 by jwe]
jwe
parents: 2586
diff changeset
96 SLStack <string> tmp_files;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
97
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
98 // Pipe to gnuplot.
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
99 static oprocstream *plot_stream = 0;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
100
2211
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
101 // ID of the plotter process.
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
102 static pid_t plot_stream_pid = 0;
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
103
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
104 // Gnuplot command strings that we use.
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
105 static string Vgnuplot_command_plot;
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
106 static string Vgnuplot_command_replot;
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
107 static string Vgnuplot_command_splot;
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
108 static string Vgnuplot_command_using;
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
109 static string Vgnuplot_command_with;
3165
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
110 static string Vgnuplot_command_axes;
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
111 static string Vgnuplot_command_title;
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
112 static string Vgnuplot_command_end;
866
f02ec9f8de65 [project @ 1994-11-02 05:19:02 by jwe]
jwe
parents: 777
diff changeset
113
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
114 static void
2209
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
115 plot_stream_death_handler (pid_t pid, int)
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
116 {
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
117 close_plot_stream ();
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
118
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
119 warning ("connection to external plotter (pid = %d) lost --", pid);
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
120 warning ("please try your plot command(s) again");
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
121 }
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
122
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
123 static void
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
124 open_plot_stream (void)
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
125 {
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
126 static bool initialized = false;
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
127
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
128 if (plot_stream && ! *plot_stream)
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
129 {
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
130 delete plot_stream;
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
131 plot_stream = 0;
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
132 }
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
133
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
134 if (! plot_stream)
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
135 {
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
136 initialized = false;
943
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
137
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
138 plot_line_count = 0;
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
139
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
140 string plot_prog = Vgnuplot_binary;
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
141
2209
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
142 if (plot_prog.empty ())
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
143 plot_prog = "gnuplot";
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
144
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
145 // XXX FIXME XXX -- I'm not sure this is the right thing to do,
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
146 // but without it, C-c at the octave prompt will kill gnuplot...
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
147
2211
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
148 #if defined (HAVE_POSIX_SIGNALS)
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
149 sigset_t set, oset;
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
150 sigemptyset (&set);
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
151 sigaddset (&set, SIGINT);
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
152 sigprocmask (SIG_BLOCK, &set, &oset);
2553
f57c52dcd5ed [project @ 1996-11-21 01:38:48 by jwe]
jwe
parents: 2543
diff changeset
153 #else
2705
18395aaeafb7 [project @ 1997-02-20 04:56:43 by jwe]
jwe
parents: 2614
diff changeset
154 volatile octave_interrupt_handler old_interrupt_handler
2553
f57c52dcd5ed [project @ 1996-11-21 01:38:48 by jwe]
jwe
parents: 2543
diff changeset
155 = octave_ignore_interrupts ();
2211
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
156 #endif
2209
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
157
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
158 plot_stream = new oprocstream (plot_prog.c_str ());
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
159
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
160 if (plot_stream)
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
161 {
2209
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
162 if (! *plot_stream)
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
163 {
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
164 delete plot_stream;
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
165 plot_stream = 0;
2209
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
166
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
167 error ("plot: unable to open pipe to `%s'", plot_prog.c_str ());
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
168 }
2209
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
169 else
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
170 {
2211
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
171 plot_stream_pid = plot_stream->pid ();
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
172 octave_child_list::insert (plot_stream_pid,
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
173 plot_stream_death_handler);
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
174 }
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
175 }
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
176 else
2209
859030f15706 [project @ 1996-05-15 11:46:43 by jwe]
jwe
parents: 2200
diff changeset
177 error ("plot: unable to open pipe to `%s'", plot_prog.c_str ());
2211
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
178
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
179 #if defined (HAVE_POSIX_SIGNALS)
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
180 sigprocmask (SIG_SETMASK, &oset, 0);
2553
f57c52dcd5ed [project @ 1996-11-21 01:38:48 by jwe]
jwe
parents: 2543
diff changeset
181 #else
f57c52dcd5ed [project @ 1996-11-21 01:38:48 by jwe]
jwe
parents: 2543
diff changeset
182 octave_set_interrupt_handler (old_interrupt_handler);
2211
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
183 #endif
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
184 }
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
185
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
186 if (! error_state && plot_stream && *plot_stream && ! initialized)
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
187 {
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
188 initialized = true;
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
189 *plot_stream << "set data style lines\n";
943
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
190
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
191 if (gnuplot_terminal_type)
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
192 *plot_stream << "set term " << gnuplot_terminal_type
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
193 << Vgnuplot_command_end;
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
194 }
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
195 }
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
196
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
197 static int
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
198 send_to_plot_stream (const char *cmd)
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
199 {
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
200 if (! (plot_stream && *plot_stream))
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
201 {
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
202 open_plot_stream ();
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
203
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
204 if (error_state)
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
205 return -1;
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
206 }
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
207
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
208 int replot_len = Vgnuplot_command_replot.length ();
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
209 int splot_len = Vgnuplot_command_splot.length ();
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
210 int plot_len = Vgnuplot_command_plot.length ();
930
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
211
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
212 bool is_replot = (Vgnuplot_command_replot.compare (cmd, 0, replot_len) == 0);
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
213 bool is_splot = (Vgnuplot_command_splot.compare (cmd, 0, splot_len) == 0);
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
214 bool is_plot = (Vgnuplot_command_plot.compare (cmd, 0, plot_len) == 0);
661
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 637
diff changeset
215
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 637
diff changeset
216 if (plot_line_count == 0 && is_replot)
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
217 error ("replot: no previous plot");
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
218 else
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
219 {
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
220 *plot_stream << cmd;
930
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
221
661
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 637
diff changeset
222 if (! (is_replot || is_splot || is_plot)
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 637
diff changeset
223 && plot_line_count > 0
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
224 && Vautomatic_replot)
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
225 *plot_stream << Vgnuplot_command_replot << Vgnuplot_command_end;
930
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
226
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
227 plot_stream->flush ();
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
228 }
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
229
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
230 return 0;
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
231 }
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
232
581
bc813f5eb025 [project @ 1994-08-07 01:02:15 by jwe]
jwe
parents: 578
diff changeset
233 // Plotting, eh?
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
234
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
235 tree_plot_command::~tree_plot_command (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
236 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
237 delete range;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
238 delete plot_list;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
239 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
240
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
241 void
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
242 tree_plot_command::eval (void)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
243 {
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 134
diff changeset
244 if (error_state)
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
245 return;
143
7849db4b6dbc [project @ 1993-10-04 02:36:45 by jwe]
jwe
parents: 134
diff changeset
246
597
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
247 open_plot_stream ();
205b8c2ef749 [project @ 1994-08-09 19:31:39 by jwe]
jwe
parents: 592
diff changeset
248
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
249 ostrstream plot_buf;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
250
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
251 switch (ndim)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
252 {
476
de9de43ad21f [project @ 1994-06-24 16:17:47 by jwe]
jwe
parents: 452
diff changeset
253 case 1:
478
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
254 if (plot_line_count == 0)
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
255 {
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
256 if (plot_list)
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
257 plot_buf << Vgnuplot_command_plot;
478
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
258 else
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
259 {
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
260 ::error ("replot: must have something to plot");
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
261 return;
478
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
262 }
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
263 }
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
264 else
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
265 plot_buf << Vgnuplot_command_replot;
476
de9de43ad21f [project @ 1994-06-24 16:17:47 by jwe]
jwe
parents: 452
diff changeset
266 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
267
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
268 case 2:
478
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
269 if (clear_before_plotting || plot_line_count == 0)
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
270 {
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
271 plot_line_count = 0;
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
272 plot_buf << Vgnuplot_command_plot;
478
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
273 }
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
274 else
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
275 plot_buf << Vgnuplot_command_replot;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
276 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
277
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
278 case 3:
930
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
279 if (clear_before_plotting || plot_line_count == 0)
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
280 {
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
281 plot_line_count = 0;
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
282 plot_buf << Vgnuplot_command_splot;
930
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
283 }
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
284 else
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
285 plot_buf << Vgnuplot_command_replot;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
286 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
287
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
288 default:
771
e16a175a8bb5 [project @ 1994-10-05 21:59:29 by jwe]
jwe
parents: 735
diff changeset
289 gripe_2_or_3_dim_plot ();
e16a175a8bb5 [project @ 1994-10-05 21:59:29 by jwe]
jwe
parents: 735
diff changeset
290 return;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
291 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
292
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
293 if (range)
478
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
294 {
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
295 if (plot_line_count == 0)
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
296 range->print (ndim, plot_buf);
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
297 else
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
298 warning ("can't specify new plot ranges with `replot' or while\
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
299 hold is on");
90964309100b [project @ 1994-06-28 16:39:41 by jwe]
jwe
parents: 476
diff changeset
300 }
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
301
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
302 if (error_state)
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
303 return;
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
304
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
305 if (plot_list)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
306 {
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
307 int status = plot_list->print (ndim, plot_buf);
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
308
771
e16a175a8bb5 [project @ 1994-10-05 21:59:29 by jwe]
jwe
parents: 735
diff changeset
309 if (error_state || status < 0)
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
310 return;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
311 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
312
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
313 plot_buf << Vgnuplot_command_end << ends;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
314
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
315 // Just testing...
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
316 // char *message = plot_buf.str ();
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
317 // cout << "[*]" << message << "[*]\n";
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
318
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
319 if (parametric_plot && ndim == 2)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
320 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
321 warning ("can't make 2D parametric plot -- setting noparametric...");
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
322 send_to_plot_stream ("set noparametric\n");
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
323 char *message = plot_buf.str ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
324 send_to_plot_stream (message);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
325 delete [] message;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
326 send_to_plot_stream ("set parametric\n");
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
327 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
328 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
329 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
330 char *message = plot_buf.str ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
331 send_to_plot_stream (message);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
332 delete [] message;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
333 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
334 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
335
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
336 void
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
337 tree_plot_command::accept (tree_walker& tw)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
338 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
339 tw.visit_plot_command (*this);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
340 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
341
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
342 plot_limits::~plot_limits (void)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
343 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
344 delete x_range;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
345 delete y_range;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
346 delete z_range;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
347 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
348
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
349 void
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
350 plot_limits::print (int ndim, ostrstream& plot_buf)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
351 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
352 if (ndim == 2 || ndim == 3)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
353 {
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
354 if (x_range)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
355 x_range->print (plot_buf);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
356 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
357 return;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
358
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
359 if (y_range)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
360 y_range->print (plot_buf);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
361 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
362 return;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
363 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
364
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
365 if (ndim == 3 && z_range)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
366 z_range->print (plot_buf);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
367 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
368
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
369 void
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
370 plot_limits::accept (tree_walker& tw)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
371 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
372 tw.visit_plot_limits (*this);
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
373 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
374
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
375 plot_range::~plot_range (void)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
376 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
377 delete lower;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
378 delete upper;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
379 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
380
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
381 void
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
382 plot_range::print (ostrstream& plot_buf)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
383 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
384 plot_buf << " [";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
385
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
386 if (lower)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
387 {
2972
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
388 octave_value lower_val = lower->rvalue ();
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
389
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
390 if (error_state)
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
391 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 191
diff changeset
392 ::error ("evaluating lower bound of plot range");
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
393 return;
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
394 }
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
395 else
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
396 {
629
0788882808bc [project @ 1994-08-19 14:33:40 by jwe]
jwe
parents: 610
diff changeset
397 double lo = lower_val.double_value ();
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
398 plot_buf << lo;
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
399 }
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
400 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
401
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
402 plot_buf << ":";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
403
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
404 if (upper)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
405 {
2972
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
406 octave_value upper_val = upper->rvalue ();
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
407
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
408 if (error_state)
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
409 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 191
diff changeset
410 ::error ("evaluating upper bound of plot range");
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
411 return;
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
412 }
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
413 else
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
414 {
629
0788882808bc [project @ 1994-08-19 14:33:40 by jwe]
jwe
parents: 610
diff changeset
415 double hi = upper_val.double_value ();
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
416 plot_buf << hi;
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
417 }
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
418 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
419
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
420 plot_buf << "]";
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
421 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
422
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
423 void
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
424 plot_range::accept (tree_walker& tw)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
425 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
426 tw.visit_plot_range (*this);
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
427 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
428
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
429 subplot_using::~subplot_using (void)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
430 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
431 delete scanf_fmt;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
432 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
433
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
434 int
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
435 subplot_using::eval (int ndim, int n_max)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
436 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
437 if ((ndim == 2 && qual_count > 4)
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
438 || (ndim == 3 && qual_count > 3))
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
439 return -1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
440
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
441 if (qual_count > 0)
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
442 val.resize (qual_count);
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
443
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
444 for (int i = 0; i < qual_count; i++)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
445 {
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
446 if (x[i])
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
447 {
2972
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
448 octave_value tmp = x[i]->rvalue ();
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
449
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
450 if (error_state)
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
451 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 191
diff changeset
452 ::error ("evaluating plot using command");
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
453 return -1;
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
454 }
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
455
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
456 double val_tmp;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
457 if (tmp.is_defined ())
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
458 {
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
459 val_tmp = tmp.double_value ();
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
460
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
461 if (error_state)
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
462 return -1;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
463
1086
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
464 if (xisnan (val_tmp))
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
465 {
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
466 ::error ("NaN is invalid as a column specifier");
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
467 return -1;
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
468 }
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
469
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
470 int n = NINT (val_tmp);
1086
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
471
322
d93ab6bf48d7 [project @ 1994-02-02 04:30:42 by jwe]
jwe
parents: 240
diff changeset
472 if (n < 1 || n_max > 0 && n > n_max)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
473 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 191
diff changeset
474 ::error ("using: column %d out of range", n);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
475 return -1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
476 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
477 else
2305
5a3f1d00a474 [project @ 1996-07-09 16:20:40 by jwe]
jwe
parents: 2289
diff changeset
478 val (i) = n;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
479 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
480 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
481 return -1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
482 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
483 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
484 return -1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
485 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
486
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
487 if (scanf_fmt)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
488 warning ("ignoring scanf format in plot command");
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
489
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
490 return 0;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
491 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
492
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
493 ColumnVector
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
494 subplot_using::values (int ndim, int n_max)
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
495 {
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
496 int status = eval (ndim, n_max);
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
497
1203
da56532815ee [project @ 1995-04-03 22:58:38 by jwe]
jwe
parents: 1192
diff changeset
498 if (status < 0)
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
499 return -1;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
500
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
501 return val;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
502 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
503
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
504 int
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
505 subplot_using::print (int ndim, int n_max, ostrstream& plot_buf)
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
506 {
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
507 int status = eval (ndim, n_max);
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
508
1203
da56532815ee [project @ 1995-04-03 22:58:38 by jwe]
jwe
parents: 1192
diff changeset
509 if (status < 0)
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
510 return -1;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
511
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
512 for (int i = 0; i < qual_count; i++)
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
513 {
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
514 if (i == 0)
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
515 plot_buf << " " << Vgnuplot_command_using << " ";
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
516 else
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
517 plot_buf << ":";
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
518
2305
5a3f1d00a474 [project @ 1996-07-09 16:20:40 by jwe]
jwe
parents: 2289
diff changeset
519 plot_buf << val (i);
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
520 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
521
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
522 return 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
523 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
524
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
525 void
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
526 subplot_using::accept (tree_walker& tw)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
527 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
528 tw.visit_subplot_using (*this);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
529 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
530
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
531 subplot_style::~subplot_style (void)
1622
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
532 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
533 delete sp_linetype;
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
534 delete sp_pointtype;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
535 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
536
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
537 int
578
d169be9237fb [project @ 1994-08-03 20:06:54 by jwe]
jwe
parents: 543
diff changeset
538 subplot_style::print (ostrstream& plot_buf)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
539 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
540 if (! sp_style.empty ())
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
541 {
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
542 plot_buf << " " << Vgnuplot_command_with << " " << sp_style;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
543
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
544 if (sp_linetype)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
545 {
2972
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
546 octave_value tmp = sp_linetype->rvalue ();
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
547
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
548 if (! error_state && tmp.is_defined ())
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
549 {
629
0788882808bc [project @ 1994-08-19 14:33:40 by jwe]
jwe
parents: 610
diff changeset
550 double val = tmp.double_value ();
1086
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
551 if (xisnan (val))
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
552 {
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
553 ::error ("NaN is invalid a plotting line style");
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
554 return -1;
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
555 }
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
556 else
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
557 plot_buf << " " << NINT (val);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
558 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
559 else
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
560 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 191
diff changeset
561 ::error ("evaluating plot style command");
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
562 return -1;
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
563 }
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
564 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
565
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
566 if (sp_pointtype)
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
567 {
2972
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
568 octave_value tmp = sp_pointtype->rvalue ();
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
569
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
570 if (! error_state && tmp.is_defined ())
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
571 {
629
0788882808bc [project @ 1994-08-19 14:33:40 by jwe]
jwe
parents: 610
diff changeset
572 double val = tmp.double_value ();
1086
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
573 if (xisnan (val))
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
574 {
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
575 ::error ("NaN is invalid a plotting point style");
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
576 return -1;
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
577 }
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
578 else
75fc98220389 [project @ 1995-01-31 04:17:15 by jwe]
jwe
parents: 1009
diff changeset
579 plot_buf << " " << NINT (val);
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
580 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
581 else
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
582 {
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 191
diff changeset
583 ::error ("evaluating plot style command");
191
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
584 return -1;
b6b4d8c513fe [project @ 1993-10-29 23:41:39 by jwe]
jwe
parents: 143
diff changeset
585 }
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
586 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
587 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
588 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
589 return -1;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
590
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
591 return 0;
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
592 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
593
2543
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
594 bool
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
595 subplot_style::columns_ok (int nc)
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
596 {
2543
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
597 bool retval = true;
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
598
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
599 if ((almost_match ("boxes", sp_style, 5, 0) && nc != 3)
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
600 || (almost_match ("boxerrorbars", sp_style, 5, 0)
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
601 && (! (nc == 3 || nc == 4 || nc == 5)))
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
602 || ((almost_match ("boxxyerrorbars", sp_style, 4, 0)
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
603 || almost_match ("xyerrorbars", sp_style, 2, 0))
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
604 && (! (nc == 4 || nc == 6 || nc == 7)))
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
605 || ((almost_match ("candlesticks", sp_style, 1, 0)
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
606 || almost_match ("financebars", sp_style, 2, 0))
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
607 && nc != 5)
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
608 || ((almost_match ("errorbars", sp_style, 1, 0)
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
609 || almost_match ("xerrorbars", sp_style, 1, 0)
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
610 || almost_match ("yerrorbars", sp_style, 1, 0))
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
611 && (! (nc == 3 || nc == 4))))
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
612 {
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
613 error
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
614 ("invalid number of data columns = %d specified for plot style `%s'",
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
615 nc, sp_style.c_str ());
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
616
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
617 retval = false;
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
618 }
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
619
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
620 return retval;
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
621 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
622
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
623 void
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
624 subplot_style::accept (tree_walker& tw)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
625 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
626 tw.visit_subplot_style (*this);
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
627 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
628
3165
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
629 int
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
630 subplot_axes::print (ostrstream& plot_buf)
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
631 {
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
632 if (! sp_axes.empty ())
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
633 plot_buf << " " << Vgnuplot_command_axes << " " << sp_axes;
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
634
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
635 return 0;
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
636 }
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
637
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
638 void
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
639 subplot_axes::accept (tree_walker& tw)
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
640 {
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
641 tw.visit_subplot_axes (*this);
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
642 }
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
643
878
e8a677c3f042 [project @ 1994-11-05 03:23:14 by jwe]
jwe
parents: 872
diff changeset
644 subplot::~subplot (void)
e8a677c3f042 [project @ 1994-11-05 03:23:14 by jwe]
jwe
parents: 872
diff changeset
645 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
646 delete sp_plot_data;
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
647 delete sp_using_clause;
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
648 delete sp_title_clause;
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
649 delete sp_style_clause;
3165
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
650 delete sp_axes_clause;
878
e8a677c3f042 [project @ 1994-11-05 03:23:14 by jwe]
jwe
parents: 872
diff changeset
651 }
e8a677c3f042 [project @ 1994-11-05 03:23:14 by jwe]
jwe
parents: 872
diff changeset
652
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
653 octave_value
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
654 subplot::extract_plot_data (int ndim, octave_value& data)
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
655 {
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
656 octave_value retval;
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
657
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
658 if (sp_using_clause)
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
659 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
660 ColumnVector val = sp_using_clause->values (ndim);
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
661
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
662 octave_value_list args;
2963
c0c280cda856 [project @ 1997-05-12 03:25:07 by jwe]
jwe
parents: 2936
diff changeset
663
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
664 args(1) = val;
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
665 args(0) = octave_value::magic_colon_t;
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
666
2963
c0c280cda856 [project @ 1997-05-12 03:25:07 by jwe]
jwe
parents: 2936
diff changeset
667 retval = data.do_index_op (args);
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
668
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
669 if (error_state)
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
670 return octave_value ();
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
671 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
672 else
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
673 {
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
674 retval = data;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
675 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
676
2543
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
677 int nc = retval.columns ();
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
678
2543
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
679 if (ndim == 2 && sp_style_clause && ! sp_style_clause->columns_ok (nc))
050924aee81a [project @ 1996-11-20 03:03:01 by jwe]
jwe
parents: 2542
diff changeset
680 return octave_value ();
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
681
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
682 return retval;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
683 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
684
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
685 int
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
686 subplot::handle_plot_data (int ndim, ostrstream& plot_buf)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
687 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
688 if (sp_plot_data)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
689 {
2972
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
690 octave_value data = sp_plot_data->rvalue ();
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
691
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
692 if (! error_state && data.is_defined ())
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
693 {
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
694 string file;
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
695
610
14b2a186a5c0 [project @ 1994-08-14 00:55:49 by jwe]
jwe
parents: 607
diff changeset
696 if (data.is_string ())
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
697 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
698 // Should really try to look at data file to determine
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
699 // n_max. Can't do much about other arbitrary gnuplot
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
700 // commands though...
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
701
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
702 int n_max = 0;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
703
2926
66ef74ee5d9f [project @ 1997-05-05 03:20:52 by jwe]
jwe
parents: 2891
diff changeset
704 file = file_ops::tilde_expand (data.string_value ());
1728
42b4f904f1af [project @ 1996-01-09 11:36:01 by jwe]
jwe
parents: 1690
diff changeset
705
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
706 ifstream ftmp (file.c_str ());
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
707
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
708 if (ftmp)
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
709 {
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
710 plot_buf << " \"" << file << '"';
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
711 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
712 else
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
713 {
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
714 file = "";
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
715
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
716 // Opening as a file failed. Let's try passing it
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
717 // along as a plot command.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
718
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
719 plot_buf << " " << data.string_value ();
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
720 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
721
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
722 if (sp_using_clause)
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
723 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
724 int status = sp_using_clause->print (ndim, n_max, plot_buf);
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
725
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
726 if (status < 0)
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
727 return -1;
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
728 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
729 }
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
730 else
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
731 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
732 // Eliminate the need for printing a using clause to
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
733 // plot_buf.
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
734
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
735 octave_value tmp_data = extract_plot_data (ndim, data);
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
736
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
737 if (tmp_data.is_defined ())
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
738 {
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
739 switch (ndim)
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
740 {
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
741 case 2:
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
742 file = save_in_tmp_file (tmp_data, ndim);
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
743 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
744
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
745 case 3:
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
746 file = save_in_tmp_file (tmp_data, ndim,
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
747 parametric_plot);
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
748 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
749
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
750 default:
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
751 gripe_2_or_3_dim_plot ();
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
752 break;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
753 }
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
754
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
755 if (file.length () > 0)
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
756 {
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
757 mark_for_deletion (file);
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
758 plot_buf << " \"" << file << '"';
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
759 }
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
760 }
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
761 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
762 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
763 else
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
764 return -1;
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
765 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
766 else
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
767 return -1;
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
768
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
769 return 0;
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
770 }
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
771
872
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
772 int
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
773 subplot::print (int ndim, ostrstream& plot_buf)
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
774 {
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
775 int status = handle_plot_data (ndim, plot_buf);
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
776
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
777 if (status < 0)
fb24794ef0e2 [project @ 1994-11-04 00:59:24 by jwe]
jwe
parents: 871
diff changeset
778 return -1;
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
779
3165
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
780 if (sp_axes_clause)
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
781 {
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
782 int status = sp_axes_clause->print (plot_buf);
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
783 if (status < 0)
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
784 return -1;
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
785 }
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
786
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
787 if (sp_title_clause)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
788 {
2972
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
789 octave_value tmp = sp_title_clause->rvalue ();
ae2471c4e5c0 [project @ 1997-05-15 19:22:05 by jwe]
jwe
parents: 2963
diff changeset
790
610
14b2a186a5c0 [project @ 1994-08-14 00:55:49 by jwe]
jwe
parents: 607
diff changeset
791 if (! error_state && tmp.is_string ())
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
792 plot_buf << " " << Vgnuplot_command_title << " "
866
f02ec9f8de65 [project @ 1994-11-02 05:19:02 by jwe]
jwe
parents: 777
diff changeset
793 << '"' << tmp.string_value () << '"';
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
794 else
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
795 {
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
796 warning ("line title must be a string");
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
797 plot_buf << " " << Vgnuplot_command_title << " "
866
f02ec9f8de65 [project @ 1994-11-02 05:19:02 by jwe]
jwe
parents: 777
diff changeset
798 << '"' << "line " << plot_line_count << '"';
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
799 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
800 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
801 else
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
802 plot_buf << " " << Vgnuplot_command_title << " "
866
f02ec9f8de65 [project @ 1994-11-02 05:19:02 by jwe]
jwe
parents: 777
diff changeset
803 << '"' << "line " << plot_line_count << '"';
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
804
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
805 if (sp_style_clause)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
806 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
807 int status = sp_style_clause->print (plot_buf);
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
808 if (status < 0)
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
809 return -1;
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
810 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
811
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
812 return 0;
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
813 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
814
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
815 void
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
816 subplot::accept (tree_walker& tw)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
817 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
818 tw.visit_subplot (*this);
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
819 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
820
1622
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
821 subplot_list::~subplot_list (void)
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
822 {
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
823 while (! empty ())
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
824 {
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
825 subplot *t = remove_front ();
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
826 delete t;
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
827 }
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
828 }
2aed00132ba2 [project @ 1995-11-06 17:36:48 by jwe]
jwe
parents: 1488
diff changeset
829
883
ff0bbf26b028 [project @ 1994-11-06 00:22:31 by jwe]
jwe
parents: 878
diff changeset
830 int
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
831 subplot_list::print (int ndim, ostrstream& plot_buf)
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
832 {
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
833 int status = 0;
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
834
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
835 for (Pix p = first (); p != 0; next (p))
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
836 {
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
837 subplot *elt = this->operator () (p);
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
838
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
839 plot_line_count++;
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
840
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
841 if (p != first ())
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
842 plot_buf << ",\\\n ";
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
843
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
844 status = elt->print (ndim, plot_buf);
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
845
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
846 if (status < 0)
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
847 break;
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
848 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
849
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
850 return status;
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
851 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
852
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
853 void
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
854 subplot_list::accept (tree_walker& tw)
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
855 {
2124
97a566037a75 [project @ 1996-05-12 07:16:36 by jwe]
jwe
parents: 2086
diff changeset
856 tw.visit_subplot_list (*this);
591
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
857 }
7563a815389b [project @ 1994-08-09 01:18:36 by jwe]
jwe
parents: 584
diff changeset
858
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
859 string
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
860 save_in_tmp_file (octave_value& t, int ndim, bool parametric)
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
861 {
2936
87cb7614257d [project @ 1997-05-06 05:46:00 by jwe]
jwe
parents: 2926
diff changeset
862 string name = file_ops::tempnam ("", "oct-");
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
863
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
864 if (! name.empty ())
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
865 {
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
866 ofstream file (name.c_str ());
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
867
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
868 if (file)
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
869 {
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
870 switch (ndim)
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
871 {
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
872 case 2:
2799
d77a29e4387f [project @ 1997-03-08 08:35:56 by jwe]
jwe
parents: 2705
diff changeset
873 save_ascii_data (file, t, name, true);
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
874 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
875
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
876 case 3:
607
ae3b8b2924a0 [project @ 1994-08-13 20:11:17 by jwe]
jwe
parents: 597
diff changeset
877 save_three_d (file, t, parametric);
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
878 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
879
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
880 default:
771
e16a175a8bb5 [project @ 1994-10-05 21:59:29 by jwe]
jwe
parents: 735
diff changeset
881 gripe_2_or_3_dim_plot ();
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
882 break;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
883 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
884 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
885 else
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
886 {
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
887 error ("couldn't open temporary output file `%s'", name.c_str ());
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
888 name.resize (0);
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
889 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
890 }
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
891
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
892 return name;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
893 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
894
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
895 void
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
896 mark_for_deletion (const string& file)
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
897 {
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
898 tmp_files.push (file);
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
899 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
900
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
901 void
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
902 cleanup_tmp_files (void)
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
903 {
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
904 while (! tmp_files.empty ())
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
905 {
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
906 string filename = tmp_files.pop ();
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
907 unlink (filename.c_str ());
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
908 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
909 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
910
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
911 void
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
912 close_plot_stream (void)
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
913 {
2211
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
914 octave_child_list::remove (plot_stream_pid);
71aef7b5339e [project @ 1996-05-15 13:00:17 by jwe]
jwe
parents: 2209
diff changeset
915
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
916 if (plot_stream)
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
917 {
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
918 delete plot_stream;
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
919 plot_stream = 0;
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
920 }
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
921
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
922 plot_line_count = 0;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
923 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
924
1328
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
925 void
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
926 do_external_plotter_cd (const string& newdir)
1328
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
927 {
1449
df589c97e140 [project @ 1995-09-20 03:49:51 by jwe]
jwe
parents: 1358
diff changeset
928 if (plot_stream && *plot_stream)
1328
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
929 {
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
930 ostrstream plot_buf;
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
931 plot_buf << "cd \"" << newdir << "\"" << Vgnuplot_command_end << ends;
1328
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
932 char *message = plot_buf.str ();
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
933 send_to_plot_stream (message);
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
934 delete [] message;
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
935 }
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
936 }
ec2ab864e8eb [project @ 1995-08-22 22:32:34 by jwe]
jwe
parents: 1315
diff changeset
937
1957
0e6a0a271998 [project @ 1996-02-15 01:08:15 by jwe]
jwe
parents: 1827
diff changeset
938 DEFUN (clearplot, , ,
883
ff0bbf26b028 [project @ 1994-11-06 00:22:31 by jwe]
jwe
parents: 878
diff changeset
939 "clearplot (): clear the plot window")
ff0bbf26b028 [project @ 1994-11-06 00:22:31 by jwe]
jwe
parents: 878
diff changeset
940 {
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
941 octave_value_list retval;
883
ff0bbf26b028 [project @ 1994-11-06 00:22:31 by jwe]
jwe
parents: 878
diff changeset
942 send_to_plot_stream ("clear\n");
930
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
943
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
944 // XXX FIXME XXX -- instead of just clearing these things, it would
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
945 // be nice if we could reset things to a user-specified default
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
946 // state.
930
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
947
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
948 send_to_plot_stream ("set title\n");
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
949 send_to_plot_stream ("set xlabel\n");
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
950 send_to_plot_stream ("set ylabel\n");
940
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 930
diff changeset
951 send_to_plot_stream ("set nogrid\n");
1000
de0df9547e08 [project @ 1994-12-21 15:56:47 by jwe]
jwe
parents: 999
diff changeset
952 send_to_plot_stream ("set nolabel\n");
940
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 930
diff changeset
953
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
954 // This makes a simple `replot' not work after a `clearplot' command
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
955 // has been issued.
940
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 930
diff changeset
956
16062e9a6b7e [project @ 1994-11-21 15:41:05 by jwe]
jwe
parents: 930
diff changeset
957 plot_line_count = 0;
930
b02124748d40 [project @ 1994-11-16 01:40:19 by jwe]
jwe
parents: 929
diff changeset
958
883
ff0bbf26b028 [project @ 1994-11-06 00:22:31 by jwe]
jwe
parents: 878
diff changeset
959 return retval;
ff0bbf26b028 [project @ 1994-11-06 00:22:31 by jwe]
jwe
parents: 878
diff changeset
960 }
ff0bbf26b028 [project @ 1994-11-06 00:22:31 by jwe]
jwe
parents: 878
diff changeset
961
884
d92f1ea6d0cd [project @ 1994-11-06 00:42:40 by jwe]
jwe
parents: 883
diff changeset
962 DEFALIAS (clg, clearplot);
d92f1ea6d0cd [project @ 1994-11-06 00:42:40 by jwe]
jwe
parents: 883
diff changeset
963
1957
0e6a0a271998 [project @ 1996-02-15 01:08:15 by jwe]
jwe
parents: 1827
diff changeset
964 DEFUN (closeplot, , ,
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
965 "closeplot (): close the stream to plotter")
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
966 {
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
967 octave_value_list retval;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
968 close_plot_stream ();
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
969 return retval;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
970 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
971
1957
0e6a0a271998 [project @ 1996-02-15 01:08:15 by jwe]
jwe
parents: 1827
diff changeset
972 DEFUN_TEXT (hold, args, ,
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
973 "hold [on|off]\n\
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
974 \n\
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
975 determine whether the plot window is cleared before the next line is\n\
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
976 drawn. With no argument, toggle the current state.")
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
977 {
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
978 octave_value_list retval;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
979
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
980 int argc = args.length () + 1;
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
981
1968
a2e206524aa0 [project @ 1996-02-17 02:54:24 by jwe]
jwe
parents: 1957
diff changeset
982 string_vector argv = args.make_argv ("hold");
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
983
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
984 if (error_state)
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
985 return retval;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
986
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
987 switch (argc)
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
988 {
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
989 case 1:
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
990 clear_before_plotting = ! clear_before_plotting;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
991 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
992
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
993 case 2:
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
994 if (argv[1] == "on")
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
995 clear_before_plotting = false;
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
996 else if (argv[1] == "off")
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
997 clear_before_plotting = true;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
998 else
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
999 print_usage ("hold");
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1000 break;
777
a2f9d3fd720c [project @ 1994-10-07 14:01:53 by jwe]
jwe
parents: 771
diff changeset
1001
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1002 default:
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1003 print_usage ("hold");
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1004 break;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1005 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1006
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1007 return retval;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1008 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1009
1957
0e6a0a271998 [project @ 1996-02-15 01:08:15 by jwe]
jwe
parents: 1827
diff changeset
1010 DEFUN (ishold, , ,
735
7455048010b9 [project @ 1994-09-24 03:22:34 by jwe]
jwe
parents: 662
diff changeset
1011 "ishold\n\
7455048010b9 [project @ 1994-09-24 03:22:34 by jwe]
jwe
parents: 662
diff changeset
1012 \n\
7455048010b9 [project @ 1994-09-24 03:22:34 by jwe]
jwe
parents: 662
diff changeset
1013 Return 1 if hold is on, otherwise return 0.")
7455048010b9 [project @ 1994-09-24 03:22:34 by jwe]
jwe
parents: 662
diff changeset
1014 {
2800
9aeba8e006a4 [project @ 1997-03-09 09:50:20 by jwe]
jwe
parents: 2799
diff changeset
1015 return static_cast<double> (! clear_before_plotting);
735
7455048010b9 [project @ 1994-09-24 03:22:34 by jwe]
jwe
parents: 662
diff changeset
1016 }
7455048010b9 [project @ 1994-09-24 03:22:34 by jwe]
jwe
parents: 662
diff changeset
1017
1957
0e6a0a271998 [project @ 1996-02-15 01:08:15 by jwe]
jwe
parents: 1827
diff changeset
1018 DEFUN (purge_tmp_files, , ,
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1019 "delete temporary data files used for plotting")
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1020 {
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
1021 octave_value_list retval;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1022 cleanup_tmp_files ();
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1023 return retval;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1024 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1025
3180
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1026
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1027 DEFUN (graw, args, ,
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1028 "graw (string)\n\
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1029 \n\
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1030 Send STRING directly to gnuplot subprocess.")
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1031 {
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1032 octave_value_list retval;
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1033
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1034 if (args.length () == 1 && args(0).is_string ())
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1035 {
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1036 string cmd = args(0).string_value ();
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1037
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1038 if (! (plot_stream && *plot_stream))
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1039 open_plot_stream ();
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1040
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1041 if (! error_state)
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1042 {
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1043 *plot_stream << cmd;
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1044
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1045 plot_stream->flush ();
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1046 }
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1047 }
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1048 else
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1049 print_usage ("graw");
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1050
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1051 return retval;
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1052 }
c17387059fd3 [project @ 1998-09-24 18:59:11 by jwe]
jwe
parents: 3165
diff changeset
1053
2520
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1054 DEFUN_TEXT (gset, args, ,
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1055 "gset [options]\n\
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1056 \n\
2520
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1057 set plotting options for gnuplot")
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1058 {
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
1059 octave_value_list retval;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1060
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1061 int argc = args.length () + 1;
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1062
1968
a2e206524aa0 [project @ 1996-02-17 02:54:24 by jwe]
jwe
parents: 1957
diff changeset
1063 string_vector argv = args.make_argv ("set");
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1064
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1065 if (error_state)
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1066 return retval;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1067
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1068 ostrstream plot_buf;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1069
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1070 if (argc > 1)
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1071 {
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1072 if (almost_match ("parametric", argv[1], 3))
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
1073 parametric_plot = true;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1074 else if (almost_match ("noparametric", argv[1], 5))
1827
effa9400766f [project @ 1996-02-02 14:07:51 by jwe]
jwe
parents: 1802
diff changeset
1075 parametric_plot = false;
943
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
1076 else if (almost_match ("term", argv[1], 1))
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
1077 {
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
1078 delete [] gnuplot_terminal_type;
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
1079 ostrstream buf;
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
1080 for (int i = 2; i < argc; i++)
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
1081 buf << argv[i] << " ";
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1082 buf << Vgnuplot_command_end << ends;
943
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
1083 gnuplot_terminal_type = buf.str ();
4fc1ae8c24dc [project @ 1994-11-21 19:05:31 by jwe]
jwe
parents: 940
diff changeset
1084 }
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1085 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1086
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1087 for (int i = 0; i < argc; i++)
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1088 plot_buf << argv[i] << " ";
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1089
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1090 plot_buf << Vgnuplot_command_end << ends;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1091
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1092 char *plot_command = plot_buf.str ();
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1093 send_to_plot_stream (plot_command);
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1094
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1095 delete [] plot_command;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1096
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1097 return retval;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1098 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1099
2520
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1100 DEFUN_TEXT (set, args, nargout,
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1101 "This command is has been replaced by `gset'.")
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1102 {
2521
19b33e933eae [project @ 1996-11-15 05:28:26 by jwe]
jwe
parents: 2520
diff changeset
1103 warning ("set is obsolete -- use gset instead");
2520
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1104 return Fgset (args, nargout);
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1105 }
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1106
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1107 DEFUN_TEXT (gshow, args, ,
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1108 "gshow [options]\n\
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1109 \n\
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1110 show plotting options")
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1111 {
2086
bfb775fb6fe8 [project @ 1996-04-25 05:55:19 by jwe]
jwe
parents: 1996
diff changeset
1112 octave_value_list retval;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1113
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1114 int argc = args.length () + 1;
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1115
1968
a2e206524aa0 [project @ 1996-02-17 02:54:24 by jwe]
jwe
parents: 1957
diff changeset
1116 string_vector argv = args.make_argv ("show");
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1117
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1118 if (error_state)
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
1119 return retval;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1120
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1121 ostrstream plot_buf;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1122
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1123 for (int i = 0; i < argc; i++)
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1124 plot_buf << argv[i] << " ";
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1125
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1126 plot_buf << Vgnuplot_command_end << ends;
524
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1127
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1128 char *plot_command = plot_buf.str ();
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1129 send_to_plot_stream (plot_command);
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1130
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1131 delete [] plot_command;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1132
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1133 return retval;
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1134 }
2814c75c8398 [project @ 1994-07-20 18:36:24 by jwe]
jwe
parents: 491
diff changeset
1135
2520
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1136 DEFUN_TEXT (show, args, nargout,
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1137 "This command is has been replaced by `gshow'.")
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1138 {
2521
19b33e933eae [project @ 1996-11-15 05:28:26 by jwe]
jwe
parents: 2520
diff changeset
1139 warning ("show is obsolete -- use gshow instead");
2520
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1140 return Fgshow (args, nargout);
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1141 }
a034dcdbc282 [project @ 1996-11-15 04:57:21 by jwe]
jwe
parents: 2508
diff changeset
1142
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1143 static int
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1144 automatic_replot (void)
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1145 {
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1146 Vautomatic_replot = check_preference ("automatic_replot");
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1147
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1148 return 0;
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1149 }
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1150
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1151 static int
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1152 set_string_var (string& var, const char *nm)
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1153 {
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1154 int retval = 0;
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1155
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1156 string s = builtin_string_variable (nm);
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1157
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1158 if (s.empty ())
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1159 {
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1160 gripe_invalid_value_specified (nm);
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1161 retval = -1;
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1162 }
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1163 else
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1164 var = s;
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1165
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1166 return retval;
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1167 }
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1168
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1169 static int
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1170 gnuplot_binary (void)
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1171 {
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1172 return set_string_var (Vgnuplot_binary, "gnuplot_binary");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1173 }
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1174
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1175 static int
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1176 gnuplot_command_plot (void)
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1177 {
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1178 return set_string_var (Vgnuplot_command_plot, "gnuplot_command_plot");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1179 }
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1180
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1181 static int
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1182 gnuplot_command_replot (void)
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1183 {
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1184 return set_string_var (Vgnuplot_command_replot, "gnuplot_command_replot");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1185 }
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1186
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1187 static int
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1188 gnuplot_command_splot (void)
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1189 {
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1190 return set_string_var (Vgnuplot_command_splot, "gnuplot_command_splot");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1191 }
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1192
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1193 static int
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1194 gnuplot_command_using (void)
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1195 {
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1196 return set_string_var (Vgnuplot_command_using, "gnuplot_command_using");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1197 }
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1198
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1199 static int
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1200 gnuplot_command_with (void)
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1201 {
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1202 return set_string_var (Vgnuplot_command_with, "gnuplot_command_with");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1203 }
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1204
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1205 static int
3165
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1206 gnuplot_command_axes (void)
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1207 {
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1208 return set_string_var (Vgnuplot_command_axes, "gnuplot_command_axes");
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1209 }
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1210
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1211 static int
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1212 gnuplot_command_title (void)
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1213 {
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1214 return set_string_var (Vgnuplot_command_title, "gnuplot_command_title");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1215 }
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1216
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1217 static int
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1218 gnuplot_command_end (void)
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1219 {
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1220 return set_string_var (Vgnuplot_command_end, "gnuplot_command_end");
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1221 }
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1222
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1223 static int
2289
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1224 gnuplot_has_frames (void)
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1225 {
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1226 Vgnuplot_has_frames = check_preference ("gnuplot_has_frames");
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1227
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1228 return 0;
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1229 }
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1230
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1231 static int
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1232 gnuplot_has_multiplot (void)
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1233 {
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1234 Vgnuplot_has_multiplot = check_preference ("gnuplot_has_multiplot");
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1235
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1236 return 0;
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1237 }
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1238
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1239 void
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1240 symbols_of_pt_plot (void)
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1241 {
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1242 DEFVAR (automatic_replot, 0.0, 0, automatic_replot,
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1243 "if true, auto-insert a replot command when a plot changes");
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1244
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1245 DEFVAR (gnuplot_binary, "gnuplot", 0, gnuplot_binary,
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1246 "path to gnuplot binary");
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1247
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1248 DEFVAR (gnuplot_command_plot, "pl", 0, gnuplot_command_plot,
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1249 "");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1250
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1251 DEFVAR (gnuplot_command_replot, "rep", 0, gnuplot_command_replot,
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1252 "");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1253
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1254 DEFVAR (gnuplot_command_splot, "sp", 0, gnuplot_command_splot,
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1255 "");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1256
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1257 DEFVAR (gnuplot_command_using, "u", 0, gnuplot_command_using,
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1258 "");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1259
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1260 DEFVAR (gnuplot_command_with, "w", 0, gnuplot_command_with,
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1261 "");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1262
3165
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1263 DEFVAR (gnuplot_command_axes, "ax", 0, gnuplot_command_axes,
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1264 "");
e4bbfc196e53 [project @ 1998-04-16 03:01:47 by jwe]
jwe
parents: 3162
diff changeset
1265
3162
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1266 DEFVAR (gnuplot_command_title, "t", 0, gnuplot_command_title,
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1267 "");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1268
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1269 DEFVAR (gnuplot_command_end, "\n", 0, gnuplot_command_end,
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1270 "");
7c96e85c76db [project @ 1998-04-08 18:19:35 by jwe]
jwe
parents: 3156
diff changeset
1271
2289
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1272 #ifdef GNUPLOT_HAS_FRAMES
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1273 double with_frames = 1.0;
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1274 #else
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1275 double with_frames = 0.0;
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1276 #endif
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1277
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1278 DEFVAR (gnuplot_has_frames, with_frames, 0, gnuplot_has_frames,
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1279 "true if gnuplot supports multiple plot windows on X11, false otherwise");
d9fe34ccf2bf [project @ 1996-06-06 05:05:47 by jwe]
jwe
parents: 2211
diff changeset
1280
2176
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1281 #ifdef GNUPLOT_HAS_MULTIPLOT
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1282 double with_multiplot = 1.0;
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1283 #else
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1284 double with_multiplot = 0.0;
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1285 #endif
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1286
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1287 DEFVAR (gnuplot_has_multiplot, with_multiplot, 0, gnuplot_has_multiplot,
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1288 "true if gnuplot supports multiplot, false otherwise");
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1289 }
868d82fe5fdc [project @ 1996-05-13 16:22:01 by jwe]
jwe
parents: 2124
diff changeset
1290
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1291 /*
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1292 ;;; Local Variables: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1293 ;;; mode: C++ ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1294 ;;; End: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1295 */