source: trunk/MagicSoft/Mars/showplot.cc@ 7775

Last change on this file since 7775 was 7573, checked in by tbretz, 19 years ago
*** empty log message ***
File size: 9.4 KB
Line 
1#include <TROOT.h>
2#include <TClass.h>
3#include <TGClient.h>
4#include <TRint.h>
5
6#include "MLog.h"
7#include "MLogManip.h"
8
9#include "MArgs.h"
10
11#include "MStatusDisplay.h"
12
13using namespace std;
14
15static void StartUpMessage()
16{
17 // 1 2 3 4 5
18 // 12345678901234567890123456789012345678901234567890
19 gLog << endl;
20 gLog << "showplot --- Mars V" << MARSVER << " compiled on <" << __DATE__ << "> using ROOT v" << ROOTVER << endl;
21 gLog << endl;
22}
23
24static void Usage()
25{
26 // 1 2 3 4 5 6 7 8
27 // 12345678901234567890123456789012345678901234567890123456789012345678901234567890
28 gLog << all << endl;
29 gLog << "Sorry the usage is:" << endl;
30 gLog << " showplot [options] {filename}|{filetype number}" << endl << endl;
31 gLog << " Arguments:" << endl;
32 gLog << " filename Input file containing an MStatusArray" << endl;
33 gLog << " filetype number Open file of filetype calib, signal, star, etc." << endl;
34 gLog << " of sequence or dataset number" << endl << endl;
35 gLog << " Root Options:" << endl;
36 gLog << " -b Batch mode (no graphical output to screen)" << endl<<endl;
37 gLog << " -r Start the root interpreter" << endl<<endl;
38 gLog << " Options: "<< endl;
39 gLog.Usage();
40 gLog << " -q Quit when job is finished" << endl;
41 gLog << endl;
42 gLog << " General Output Options: "<< endl;
43 gLog << " --print[=printer] Print to printer" << endl;
44 gLog << " --save-as-ps[=filename] Save plots as postscript" << endl;
45 gLog << " --save-as-pdf[=filename] Save plots as pdf-file" << endl;
46 gLog << " --save-as-svg[=filename] Save plots as svg-file" << endl;
47 gLog << " --save-as-root[=filename] Save plots as root file" << endl;
48 gLog << " --save-as-C[=filename] Save plots as root scripts" << endl;
49 gLog << " --tab=num Save only tab number num" << endl << endl;
50 gLog << " Print only options:" << endl;
51 gLog << " --print-cmd='lpr -P%p %f' Set the printer command" << endl;
52 gLog << " --print-dir=/tmp Set the printing temp directory" << endl << endl;
53 gLog << " GUI only options:" << endl;
54 gLog << " --save-as-gif[=filename] Save plots as gif files" << endl;
55 gLog << " --save-as-jpg[=filename] Save plots as jpg files" << endl;
56 gLog << " --save-as-xpm[=filename] Save plots as xpm files" << endl;
57 gLog << " --save-as-png[=filename] Save plots as png files" << endl;
58 gLog << endl;
59 gLog << " --version, -V Show startup message with version number" << endl;
60 gLog << " -?, -h, --help This help" << endl;
61 gLog << endl;
62 gLog << "Description:" << endl;
63 gLog << " Use showplot to display a MStatusArray in an MStatusDisplay." << endl;
64 gLog << " MStatusArrays are typically written by programs showing data" << endl;
65 gLog << " check plots, like callisto." << endl << endl;
66 gLog << "Printing:" << endl;
67 gLog << " For more details see MStatusDisplay::PrintPS" << endl << endl;
68 gLog << "Examples:" << endl;
69 gLog << " showplot filename.root" << endl;
70 gLog << " showplot -b --null --print --print-cmd='psnup -2 %f' filename.root | lpr" << endl;
71 gLog << " showplot -b --print --print-cmd='psbook %f | psnup -2 | lpr' filename.root" << endl;
72 gLog << " showplot -b --print --print-cmd='cat %f' filename.root > filename.ps" << endl;
73 gLog << " showplot -b --save-as-ps filename.root" << endl;
74 gLog << " showplot -q --save-as-gif=tab5.gif --tab=5 filename.root" << endl;
75 gLog << " showplot -b --save-as-ps --print=lp2 filename.root" << endl;
76 gLog << endl;
77}
78
79int main(int argc, char **argv)
80{
81 //
82 // Evaluate arguments
83 //
84 MArgs arg(argc, argv, kTRUE);
85 gLog.Setup(arg);
86
87 StartUpMessage();
88
89 if (arg.HasOnly("-V") || arg.HasOnly("--version"))
90 return 0;
91
92 if (arg.HasOnly("-?") || arg.HasOnly("-h") || arg.HasOnly("--help"))
93 {
94 Usage();
95 return 2;
96 }
97
98 const Bool_t kQuit = arg.HasOnlyAndRemove("-q");
99 const Bool_t kBatch = arg.HasOnlyAndRemove("-b");
100 const Bool_t kRoot = arg.HasOnlyAndRemove("-r");
101
102 const Int_t kTab = arg.GetIntAndRemove("--tab=", -1);
103
104 const Bool_t kPrint = arg.HasOnlyAndRemove("--print") || arg.Has("--print=");
105 const Bool_t kSaveAsPs = arg.HasOnlyAndRemove("--save-as-ps") || arg.Has("--save-as-ps=");
106 const Bool_t kSaveAsPdf = arg.HasOnlyAndRemove("--save-as-pdf") || arg.Has("--save-as-pdf=");
107 const Bool_t kSaveAsSvg = arg.HasOnlyAndRemove("--save-as-svg") || arg.Has("--save-as-svg=");
108 const Bool_t kSaveAsGif = arg.HasOnlyAndRemove("--save-as-gif") || arg.Has("--save-as-gif=");
109 const Bool_t kSaveAsJpg = arg.HasOnlyAndRemove("--save-as-jpg") || arg.Has("--save-as-jpg=");
110 const Bool_t kSaveAsXpm = arg.HasOnlyAndRemove("--save-as-xpm") || arg.Has("--save-as-xpm=");
111 const Bool_t kSaveAsPng = arg.HasOnlyAndRemove("--save-as-png") || arg.Has("--save-as-png=");
112 const Bool_t kSaveAsRoot = arg.HasOnlyAndRemove("--save-as-root") || arg.Has("--save-as-root=");
113 const Bool_t kSaveAsC = arg.HasOnlyAndRemove("--save-as-C") || arg.Has("--save-as-C=");
114
115 TString kNamePrint = arg.GetStringAndRemove("--print=");
116 TString kPrintCmd = arg.GetStringAndRemove("--print-cmd=");
117 TString kPrintDir = arg.GetStringAndRemove("--print-dir=");
118 TString kNamePs = arg.GetStringAndRemove("--save-as-ps=");
119 TString kNamePdf = arg.GetStringAndRemove("--save-as-pdf=");
120 TString kNameSvg = arg.GetStringAndRemove("--save-as-svg=");
121 TString kNameGif = arg.GetStringAndRemove("--save-as-gif=");
122 TString kNameJpg = arg.GetStringAndRemove("--save-as-jpg=");
123 TString kNameXpm = arg.GetStringAndRemove("--save-as-xpm=");
124 TString kNamePng = arg.GetStringAndRemove("--save-as-png=");
125 TString kNameRoot = arg.GetStringAndRemove("--save-as-root=");
126 TString kNameC = arg.GetStringAndRemove("--save-as-C=");
127
128
129 //
130 // check for the right usage of the program
131 //
132 if (arg.GetNumOptions()>0)
133 {
134 gLog << err << "Unknown command line options..." << endl;
135 arg.Print("options");
136 gLog << endl;
137 return 3;
138 }
139 if (arg.GetNumArguments()<1 || arg.GetNumArguments()>2)
140 {
141 Usage();
142 return 2;
143 }
144 if (arg.GetNumArguments()==2 && !arg.GetArgumentStr(1).IsDigit())
145 {
146 Usage();
147 return 2;
148 }
149
150 TApplication *app = kRoot ? new TRint("showplot", &argc, argv) : new TApplication("showplot", &argc, argv);
151 if (!gROOT->IsBatch() && !gClient || gROOT->IsBatch() && !kBatch)
152 {
153 gLog << err << "Bombing... maybe your DISPLAY variable is not set correctly!" << endl;
154 return 1;
155 }
156
157 //
158 // Process filenames
159 //
160 TString kInput = arg.GetArgumentStr(0);
161
162 //
163 // Something special for datacenter access
164 //
165 if (arg.GetNumArguments()==2)
166 {
167 const Int_t num = arg.GetArgumentStr(1).Atoi();
168 TString file = "/magic/data/";
169
170 kInput.ToLower();
171 switch (kInput.Hash())
172 {
173 case 3438106369U:
174 case 764164111U:
175 file += "callisto";
176 break;
177 default:
178 file += kInput;
179 break;
180 }
181 file += kInput==(TString)"ganymed" ? Form("/%05d", num/100000) : Form("/%04d", num/10000);
182 file += Form("/%08d/", num);
183 file += kInput;
184 file += Form("%08d.root", num);
185
186 kInput = file;
187
188 gLog << inf << "Inflated file name: " << kInput << endl;
189 }
190
191 if (kNamePs.IsNull() && kSaveAsPs)
192 kNamePs = kInput;
193 if (kNamePdf.IsNull() && kSaveAsPdf)
194 kNamePdf = kInput;
195 if (kNameSvg.IsNull() && kSaveAsSvg)
196 kNameSvg = kInput;
197 if (kNameGif.IsNull() && kSaveAsGif)
198 kNameGif = kInput;
199 if (kNameJpg.IsNull() && kSaveAsJpg)
200 kNameJpg = kInput;
201 if (kNameXpm.IsNull() && kSaveAsXpm)
202 kNameXpm = kInput;
203 if (kNamePng.IsNull() && kSaveAsPng)
204 kNamePng = kInput;
205 if (kNameRoot.IsNull() && kSaveAsRoot)
206 kNameRoot = kInput;
207 if (kNameC.IsNull() && kSaveAsC)
208 kNameC = kInput;
209
210 //
211 // Update frequency by default = 1Hz
212 //
213 MStatusDisplay *d = new MStatusDisplay;
214
215 // From now on each 'Exit' means: Terminate the application
216 d->SetTitle(kInput);
217 d->SetWindowName(kInput);
218
219 d->Open(kInput);
220
221 if (kPrint)
222 d->PrintPS(kTab, kNamePrint, kPrintCmd, kPrintDir);
223 if (kSaveAsPs)
224 d->SaveAsPS(kTab, kNamePs);
225 if (kSaveAsPdf)
226 d->SaveAsPDF(kTab, kNamePdf);
227 if (kSaveAsSvg)
228 d->SaveAsSVG(kTab, kNameSvg);
229 if (kSaveAsGif)
230 d->SaveAsGIF(kTab, kNameGif);
231 if (kSaveAsJpg)
232 d->SaveAsJPG(kTab, kNameJpg);
233 if (kSaveAsXpm)
234 d->SaveAsXPM(kTab, kNameXpm);
235 if (kSaveAsPng)
236 d->SaveAsPNG(kTab, kNamePng);
237 if (kSaveAsRoot)
238 d->SaveAsRoot(kTab, kNameRoot);
239 if (kSaveAsC)
240 d->SaveAsC(kTab, kNameC);
241
242 if (kBatch || kQuit)
243 {
244 delete d;
245 return 0;
246 }
247
248 // From now on each 'Close' means: Terminate the application
249 d->SetBit(MStatusDisplay::kExitLoopOnClose);
250
251 // Wait until the user decides to exit the application
252 app->Run(kFALSE);
253 delete app;
254 return 0;
255}
Note: See TracBrowser for help on using the repository browser.