// @(#)root/base:$Name: $:$Id: TApplication.cxx,v 1.4 2001/03/06 12:15:46 rdm Exp $
// Author: Fons Rademakers 22/12/95
/*************************************************************************
* Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
* All rights reserved. *
* *
* For the licensing terms see $ROOTSYS/LICENSE. *
* For the list of contributors see $ROOTSYS/README/CREDITS. *
*************************************************************************/
//////////////////////////////////////////////////////////////////////////
// //
// TApplication //
// //
// This class creates the ROOT Application Environment that interfaces //
// to the windowing system eventloop and eventhandlers. //
// This class must be instantiated exactly once in any given //
// application. Normally the specific application class inherits from //
// TApplication (see TRint). //
// //
//////////////////////////////////////////////////////////////////////////
#ifdef HAVE_CONFIG
#include "config.h"
#endif
#include <fstream.h>
#include "TApplication.h"
#include "TGuiFactory.h"
#include "TVirtualX.h"
#include "TROOT.h"
#include "TSystem.h"
#include "TString.h"
#include "TError.h"
#include "TObjArray.h"
#include "TObjString.h"
#include "TTimer.h"
#include "TInterpreter.h"
#include "TStyle.h"
#include "TVirtualPad.h"
#include "TEnv.h"
#include "TColor.h"
#include "TClassTable.h"
#include "TSystemDirectory.h"
TApplication *gApplication = 0;
//______________________________________________________________________________
class TIdleTimer : public TTimer {
public:
TIdleTimer(Long_t ms) : TTimer(ms, kTRUE) { }
Bool_t Notify();
};
//______________________________________________________________________________
Bool_t TIdleTimer::Notify()
{
gApplication->HandleIdleTimer();
Reset();
return kFALSE;
}
ClassImp(TApplication)
//______________________________________________________________________________
TApplication::TApplication(const char *appClassName,
int *argc, char **argv, void *options,
int numOptions)
{
// Create an application environment. The application environment
// provides an interface to the graphics system and eventloop
// (be it X, Windoze, MacOS or BeOS). After creating the application
// object start the eventloop by calling its Run() method. The command
// line options recogized by TApplication are described in the GetOptions()
// method. The recognized options are removed from the argument array.
// The original list of argument options can be retrieved via the Argc()
// and Argv() methods. The "options" and "numOptions" arguments are
// not used. The appClassName "proofserv" is reserved for the PROOF system.
if (gApplication) {
Error("TApplication", "only one instance of TApplication allowed");
return;
}
if (!gROOT)
::Fatal("TApplication::TApplication", "ROOT system not initialized");
if (!gSystem)
::Fatal("TApplication::TApplication", "gSystem not initialized");
gApplication = this;
gROOT->SetApplication(this);
// copy command line arguments, can be later accessed via Argc() and Argv()
if (argc && *argc > 0) {
fArgc = *argc;
fArgv = (char **)new char*[fArgc];
} else {
fArgc = 0;
fArgv = 0;
}
for (int i = 0; i < fArgc; i++)
fArgv[i] = StrDup(argv[i]);
GetOptions(argc, argv);
fIdleTimer = 0;
fIdleCommand = 0;
fSigHandler = 0;
fReturnFromRun = kFALSE;
fAppImp = 0;
LoadGraphicsLibs();
// Create WM dependent application environment
fAppImp = gGuiFactory->CreateApplicationImp(appClassName, argc, argv, options, numOptions);
// Try to load TrueType font renderer. Only try to load if not in batch
// mode and Root.UseTTFonts is true and Root.TTFontPath exists. Abort silently
// if libttf or libGX11TTF are not found in $ROOTSYS/lib or $ROOTSYS/ttf/lib.
#if !defined(WIN32)
if (strcmp(appClassName, "proofserv")) {
const char *ttpath = gEnv->GetValue("Root.TTFontPath",
# ifdef TTFFONTDIR
TTFFONTDIR);
# else
"$(HOME)/ttf/fonts");
# endif
char *ttfont = gSystem->Which(ttpath, "arialbd.ttf", kReadPermission);
if (!gROOT->IsBatch() && ttfont && gEnv->GetValue("Root.UseTTFonts", 1))
gROOT->LoadClass("TGX11TTF", "GX11TTF");
delete [] ttfont;
}
#endif
// Create the canvas colors early so they are allocated before
// any color table expensive bitmaps get allocated in GUI routines (like
// creation of XPM bitmaps).
InitializeColors();
// Hook for further initializing the WM dependent application environment
Init();
if (fArgv) gSystem->SetProgname(fArgv[0]);
// Set default screen factor (if not disabled in rc file)
if (gEnv->GetValue("Canvas.UseScreenFactor", 1)) {
Int_t x, y;
UInt_t w, h;
if (gVirtualX) {
gVirtualX->GetGeometry(-1, x, y, w, h);
if (h > 0 && h < 1000) gStyle->SetScreenFactor(0.0011*h);
}
}
// Make sure all registered dictionaries have been initialized
gInterpreter->InitializeDictionaries();
gInterpreter->SaveContext();
gInterpreter->SaveGlobalsContext();
gROOT->SetLineHasBeenProcessed(); // to allow user to interact with TCanvas's under WIN32
}
//______________________________________________________________________________
TApplication::~TApplication()
{
// TApplication dtor.
for (int i = 0; i < fArgc; i++)
SafeDelete(fArgv[i]);
delete [] fArgv;
SafeDelete(fAppImp);
}
//______________________________________________________________________________
void TApplication::ClearInputFiles()
{
// Clear list containing macro files passed as program arguments.
// This method is called from TRint::Run() to ensure that the macro
// files are only executed the first time Run() is called.
if (fFiles) {
fFiles->Delete();
SafeDelete(fFiles);
}
}
//______________________________________________________________________________
void TApplication::GetOptions(int *argc, char **argv)
{
// Get and handle command line options. Arguments handled are removed
// from the argument array. The following arguments are handled:
// -? : help
// -h : help
// -b : run in batch mode without graphics
// -n : do not execute logon and logoff macros as specified in .rootrc
// -q : exit after processing command line macro files
// -l : do not show splash screen
// The last three options are only relevant in conjunction with TRint.
fNoLog = kFALSE;
fQuit = kFALSE;
fFiles = 0;
if (!argc)
return;
int i, j;
for (i = 1; i < *argc; i++) {
if (!strcmp(argv[i], "-?") || !strncmp(argv[i], "-h", 2)) {
fprintf(stderr, "Usage: %s [-l] [-b] [-n] [-q] [dir] [file1.C ... fileN.C]n", argv[0]);
fprintf(stderr, "Options:n");
fprintf(stderr, " -b : run in batch mode without graphicsn");
fprintf(stderr, " -n : do not execute logon and logoff macros as specified in .rootrcn");
fprintf(stderr, " -q : exit after processing command line macro filesn");
fprintf(stderr, " -l : do not show splash screenn");
fprintf(stderr, " dir : if dir is a valid directory cd to it before executingn");
fprintf(stderr, "n");
Terminate(0);
} else if (!strcmp(argv[i], "-b")) {
gROOT->SetBatch();
if (gGuiFactory != gBatchGuiFactory) delete gGuiFactory;
gGuiFactory = gBatchGuiFactory;
#ifndef WIN32
if (gVirtualX != gGXBatch) delete gVirtualX;
#endif
gVirtualX = gGXBatch;
argv[i] = 0;
#if 0
} else if (!strcmp(argv[i], "-x")) {
// remote ROOT display server not operational yet
#ifndef WIN32
if (gVirtualX != gGXBatch) delete gVirtualX;
#endif
gVirtualX = new TGXClient("Root_Client");
if (gVirtualX->IsZombie()) {
delete gVirtualX;
gROOT->SetBatch();
if (gGuiFactory != gBatchGuiFactory) delete gGuiFactory;
gGuiFactory = gBatchGuiFactory;
gVirtualX = gGXBatch;
}
argv[i] = 0;
#endif
} else if (!strcmp(argv[i], "-n")) {
fNoLog = kTRUE;
argv[i] = 0;
} else if (!strcmp(argv[i], "-q")) {
fQuit = kTRUE;
argv[i] = 0;
} else if (!strcmp(argv[i], "-l")) {
// used by front-end program to not display splash screen
argv[i] = 0;
} else if (!strcmp(argv[i], "-splash")) {
// used when started by front-end program to signal that
// splash screen can be popped down (TRint::PrintLogo())
argv[i] = 0;
} else if (argv[i][0] != '-' && argv[i][0] != '+') {
Long_t id, size, flags, modtime;
char *dir = gSystem->ExpandPathName(argv[i]);
if (!gSystem->GetPathInfo(dir, &id, &size, &flags, &modtime) &&
(flags & 2)) { // if directory make it working directory
gSystem->ChangeDirectory(dir);
TSystemDirectory *workdir = new TSystemDirectory("workdir", gSystem->WorkingDirectory());
TObject *w = gROOT->GetListOfBrowsables()->FindObject("workdir");
TObjLink *lnk = gROOT->GetListOfBrowsables()->FirstLink();
while (lnk) {
if (lnk->GetObject() == w) {
lnk->SetObject(workdir);
lnk->SetOption(gSystem->WorkingDirectory());
break;
}
lnk = lnk->Next();
}
delete w;
delete [] dir;
continue;
}
delete [] dir;
if (!fFiles) fFiles = new TObjArray;
fFiles->Add(new TObjString(argv[i]));
}
// ignore unknown options
}
// remove handled arguments from argument array
j = 0;
for (i = 0; i < *argc; i++) {
if (argv[i]) {
argv[j] = argv[i];
j++;
}
}
*argc = j;
}
//______________________________________________________________________________
void TApplication::HandleIdleTimer()
{
// Handle idle timeout. When this timer expires the registered idle command
// will be executed by this routine.
ProcessLine(GetIdleCommand());
}
//______________________________________________________________________________
void TApplication::Help(const char *line)
{
// Print help on interpreter.
gInterpreter->ProcessLine(line);
Printf("nROOT special commands.");
Printf("===========================================================================");
Printf(" pwd : show current directory, pad and style");
Printf(" ls : list contents of current directory");
Printf(" which [file] : shows path of macro file");
}
//______________________________________________________________________________
void TApplication::InitializeColors()
{
// Initialize colors used by the TCanvas based graphics (via TColor objects).
// This method should be called before the ApplicationImp is created (which
// initializes the GUI colors).
if (gROOT->GetListOfColors()->First() == 0) {
TColor *s0;
Float_t r, g, b, h, l, s;
Int_t i;
new TColor(kWhite,1,1,1,"background");
new TColor(kBlack,0,0,0,"black");
new TColor(kRed,1,0,0,"red");
new TColor(kGreen,0,1,0,"green");
new TColor(kBlue,0,0,1,"blue");
new TColor(kYellow,1,1,0,"yellow");
new TColor(kMagenta,1,0,1,"magenta");
new TColor(kCyan,0,1,1,"cyan");
new TColor(10,0.999,0.999,0.999,"white");
new TColor(11,0.754,0.715,0.676,"editcol");
// The color cwhite above is defined as being nearly white.
// Sets the associated dark color also to white.
TColor *c110 = gROOT->GetColor(110);
c110->SetRGB(0.999,0.999,.999);
// Initialize Custom colors
new TColor(20,0.8,0.78,0.67);
new TColor(31,0.54,0.66,0.63);
new TColor(41,0.83,0.81,0.53);
new TColor(30,0.52,0.76,0.64);
new TColor(32,0.51,0.62,0.55);
new TColor(24,0.70,0.65,0.59);
new TColor(21,0.8,0.78,0.67);
new TColor(47,0.67,0.56,0.58);
new TColor(35,0.46,0.54,0.57);
new TColor(33,0.68,0.74,0.78);
new TColor(39,0.5,0.5,0.61);
new TColor(37,0.43,0.48,0.52);
new TColor(38,0.49,0.6,0.82);
new TColor(36,0.41,0.51,0.59);
new TColor(49,0.58,0.41,0.44);
new TColor(43,0.74,0.62,0.51);
new TColor(22,0.76,0.75,0.66);
new TColor(45,0.75,0.51,0.47);
new TColor(44,0.78,0.6,0.49);
new TColor(26,0.68,0.6,0.55);
new TColor(28,0.53,0.4,0.34);
new TColor(25,0.72,0.64,0.61);
new TColor(27,0.61,0.56,0.51);
new TColor(23,0.73,0.71,0.64);
new TColor(42,0.87,0.73,0.53);
new TColor(46,0.81,0.37,0.38);
new TColor(48,0.65,0.47,0.48);
new TColor(34,0.48,0.56,0.6);
new TColor(40,0.67,0.65,0.75);
new TColor(29,0.69,0.81,0.78);
// Initialize some additional greyish non saturated colors
new TColor(8, 0.35,0.83,0.33);
new TColor(9, 0.35,0.33,0.85);
new TColor(12,.3,.3,.3,"grey12");
new TColor(13,.4,.4,.4,"grey13");
new TColor(14,.5,.5,.5,"grey14");
new TColor(15,.6,.6,.6,"grey15");
new TColor(16,.7,.7,.7,"grey16");
new TColor(17,.8,.8,.8,"grey17");
new TColor(18,.9,.9,.9,"grey18");
new TColor(19,.95,.95,.95,"grey19");
new TColor(50, 0.83,0.35,0.33);
// Initialize the Pretty Palette Spectrum Violet->Red
// The color model used here is based on the HLS model which
// is much more suitable for creating palettes than RGB.
// Fixing the saturation and lightness we can scan through the
// spectrum of visible light by using "hue" alone.
// In Root hue takes values from 0 to 360.
Float_t saturation = 1;
Float_t lightness = 0.5;
Float_t MaxHue = 280;
Float_t MinHue = 0;
Int_t MaxPretty = 50;
Float_t hue;
for (i=0 ; i<MaxPretty ; i++) {
hue = MaxHue-(i+1)*((MaxHue-MinHue)/MaxPretty);
c110->HLStoRGB(hue, lightness, saturation, r, g, b);
new TColor(i+51, r, g, b);
}
// Initialize special colors for x3d
for (i = 1; i < 8; i++) {
s0 = gROOT->GetColor(i);
s0->GetRGB(r,g,b);
if (i == 1) { r = 0.6; g = 0.6; b = 0.6; }
if (r == 1) r = 0.9; if (r == 0) r = 0.1;
if (g == 1) g = 0.9; if (g == 0) g = 0.1;
if (b == 1) b = 0.9; if (b == 0) b = 0.1;
s0->RGBtoHLS(r,g,b,h,l,s);
s0->HLStoRGB(h,0.6*l,s,r,g,b);
new TColor(200+4*i-3,r,g,b);
s0->HLStoRGB(h,0.8*l,s,r,g,b);
new TColor(200+4*i-2,r,g,b);
s0->HLStoRGB(h,1.2*l,s,r,g,b);
new TColor(200+4*i-1,r,g,b);
s0->HLStoRGB(h,1.4*l,s,r,g,b);
new TColor(200+4*i ,r,g,b);
}
}
}
//______________________________________________________________________________
void TApplication::LoadGraphicsLibs()
{
// Load shared libs neccesary for graphics. These libraries are only
// loaded when gROOT->IsBatch() is kFALSE.
if (gROOT->IsBatch()) return;
gROOT->LoadClass("TCanvas", "Gpad");
#ifndef WIN32
//gSystem->Load("/usr/X11R6/lib/libX11.so");
//gSystem->Load("libXpm");
gROOT->LoadClass("TGX11", "GX11"); // implicitely loads X11 and Xpm
gROOT->LoadClass("TRootGuiFactory", "Gui");
gROOT->ProcessLineFast("new TGX11("X11", "ROOT interface to X11");");
gGuiFactory = (TGuiFactory *) gROOT->ProcessLineFast("new TRootGuiFactory();");
#else
gROOT->LoadClass("TGWin32", "Win32");
gVirtualX = (TVirtualX *) gROOT->ProcessLineFast("new TGWin32(\"Win32\", \"ROOT interface to Win32\");");
gGuiFactory = (TGuiFactory *) gROOT->ProcessLineFast("new TWin32GuiFactory();");
#endif
}
//______________________________________________________________________________
void TApplication::ProcessLine(const char *line, Bool_t sync)
{
// Process a single command line, either a C++ statement or an interpreter
// command starting with a ".".
Int_t nch = strlen(line);
if (!nch) return;
if (!strncmp(line, ".exit", 4) || !strncmp(line, ".quit", 2)) {
gInterpreter->ResetGlobals();
Terminate(0);
return;
}
if (!strncmp(line, "?", 1)) {
Help(line);
return;
}
if (!strncmp(line, ".pwd", 4)) {
if (gDirectory)
Printf("Current directory: %s", gDirectory->GetPath());
if (gPad)
Printf("Current pad: %s", gPad->GetName());
if (gStyle)
Printf("Current style: %s", gStyle->GetName());
return;
}
if (!strncmp(line, ".ls", 3)) {
const char *opt = 0;
if (line[3]) opt = &line[3];
if (gDirectory) gDirectory->ls(opt);
return;
}
if (!strncmp(line, ".which", 6)) {
char *fn = Strip(line+7);
char *mac = gSystem->Which(TROOT::GetMacroPath(), fn, kReadPermission);
if (!mac)
Printf("No macro %s in path %s", fn, TROOT::GetMacroPath());
else
Printf("%s", mac);
delete [] fn;
delete [] mac;
return;
}
if (!strncmp(line, ".L", 2)) {
char *fn = Strip(line+3);
// See if script compilation requested
char postfix[3];
postfix[0] = 0;
Bool_t compile = !strcmp(fn+strlen(fn)-1,"+");
Bool_t remove = !strcmp(fn+strlen(fn)-2,"++");
if (compile) {
if (remove) {
fn[strlen(fn)-2] = 0;
strcpy(postfix,"++");
} else {
fn[strlen(fn)-1] = 0;
strcpy(postfix,"+");
}
}
char *mac = gSystem->Which(TROOT::GetMacroPath(), fn, kReadPermission);
if (!mac)
Error("ProcessLine", "macro %s not found in path %s", fn,
TROOT::GetMacroPath());
else {
if (sync)
gInterpreter->ProcessLineSynch(Form(".L %s%s", mac,postfix));
else
gInterpreter->ProcessLine(Form(".L %s%s", mac, postfix));
}
delete [] fn;
delete [] mac;
return;
}
if (!strncmp(line, ".X", 2) || !strncmp(line, ".x", 2)) {
ProcessFile(line+3);
return;
}
if (!strcmp(line, ".reset")) {
// Do nothing, .reset disabled in CINT because too many side effects
Printf("*** .reset not allowed, please use gROOT->Reset() ***");
return;
#if 0
// delete the ROOT dictionary since CINT will destroy all objects
// referenced by the dictionary classes (TClass et. al.)
gROOT->GetListOfClasses()->Delete();
// fall through
#endif
}
if (sync)
gInterpreter->ProcessLineSynch(line);
else
gInterpreter->ProcessLine(line);
}
//______________________________________________________________________________
void TApplication::ProcessFile(const char *name)
{
// Process a file containing a C++ macro.
const Int_t kBufSize = 1024;
Int_t nch = strlen(name);
if (nch == 0) return;
char *fname = Strip(name);
if (fname[nch-1] == ';') { nch--; fname[nch] = 0; }
char *arg = strrchr(fname, '(');
if (arg) {
*arg = 0;
char *t = arg-1;
while (*t == ' ') {
*t = 0; t--;
}
}
// strip off I/O redirect tokens from filename
char ssave = 0;
char *s2 = 0;
if (!arg) {
char *s3;
s2 = strstr(fname, ">>");
if (!s2) s2 = strstr(fname, "2>");
if (!s2) s2 = strchr(fname, '>');
s3 = strchr(fname, '<');
if (s2 && s3) s2 = s2<s3 ? s2 : s3;
if (s3 && !s2) s2 = s3;
if (s2) {
s2--;
while (s2 && *s2 == ' ') s2--;
s2++;
ssave = *s2;
*s2 = 0;
}
}
// See if script compilation requested
char compile[3];
compile[0] = 0;
if (!strcmp(fname+strlen(fname)-2,"++")) {
strcpy(compile ,"++");
fname[strlen(fname)-2] = 0;
} else if (!strcmp(fname+strlen(fname)-1,"+")) {
strcpy(compile, "+");
fname[strlen(fname)-1] = 0;
}
char *exnam = gSystem->Which(TROOT::GetMacroPath(), fname, kReadPermission);
if (!exnam) {
Error("ProcessFile", "macro %s not found in path %s", fname,
TROOT::GetMacroPath());
delete [] fname;
return;
}
::ifstream file(exnam,ios::in);
if (!file.good()) {
Error("ProcessFile", "%s no such file", exnam);
delete [] exnam;
delete [] fname;
return;
}
char currentline[kBufSize];
int tempfile = 0;
int comment = 0;
int ifndefc = 0;
int ifdef = 0;
char *s = 0;
Bool_t execute = kFALSE;
while (1) {
file.getline(currentline,kBufSize);
if (file.eof()) break;
s = currentline;
while (s && *s == ' ') s++; // strip-off leading blanks
// very simple minded pre-processor parsing, only works in case macro file
// starts with "#ifndef __CINT__". In that case everything till next
// "#else" or "#endif" will be skipped.
if (*s == '#') {
char *cs = Compress(currentline);
if (strstr(cs, "#ifndef__CINT__") ||
strstr(cs, "#if!defined(__CINT__)"))
ifndefc = 1;
else if (ifndefc && (strstr(cs, "#ifdef") || strstr(cs, "#ifndef") ||
strstr(cs, "#ifdefined") || strstr(cs, "#if!defined")))
ifdef++;
else if (ifndefc && strstr(cs, "#endif")) {
if (ifdef)
ifdef--;
else
ifndefc = 0;
} else if (ifndefc && !ifdef && strstr(cs, "#else"))
ifndefc = 0;
delete [] cs;
}
if (!*s || *s == '#' || ifndefc || !strncmp(s, "//", 2)) continue;
if (!strncmp(s, ".X", 2) || !strncmp(s, ".x", 2)) {
ProcessFile(s+3);
execute = kTRUE;
continue;
}
if (!strncmp(s, "/*", 2)) comment = 1;
if (comment && !strncmp(s+strlen(s)-2, "*/", 2)) comment = 0;
if (!comment && *s == '{') tempfile = 1;
if (!comment) break;
}
file.close();
if (!execute) {
int exlen = strlen(exnam);
if (arg) exlen += strlen(arg+1)+1;
if (s2) exlen += strlen(s2+1)+1;
char *exname = new char [exlen + strlen(compile) + 1];
strcpy(exname, exnam);
if (!tempfile) {
// We have a script that does NOT contain an unamed macro,
// so we can call the script compiler on it.
strcat(exname,compile);
}
if (arg) {
*arg = '(';
strcat(exname, arg);
}
if (s2) {
*s2 = ssave;
strcat(exname, s2);
}
if (tempfile) {
gInterpreter->ProcessLineSynch(Form(".x %s", exname));
} else
gInterpreter->ProcessLineSynch(Form(".X %s", exname));
delete [] exname;
}
delete [] exnam;
delete [] fname;
}
//______________________________________________________________________________
void TApplication::Run(Bool_t retrn)
{
// Main application eventloop. Calls system dependent eventloop via gSystem.
SetReturnFromRun(retrn);
gSystem->Run();
}
//______________________________________________________________________________
void TApplication::SetIdleTimer(UInt_t idleTimeInSec, const char *command)
{
// Set the command to be executed after the system has been idle for
// idleTimeInSec seconds. Normally called via TROOT::Idle(...).
if (fIdleTimer) RemoveIdleTimer();
fIdleCommand = StrDup(command);
fIdleTimer = new TIdleTimer(idleTimeInSec*1000);
gSystem->AddTimer(fIdleTimer);
}
//______________________________________________________________________________
void TApplication::RemoveIdleTimer()
{
// Remove idle timer. Normally called via TROOT::Idle(0).
if (fIdleTimer) {
// timers are removed from the gSystem timer list by their dtor
SafeDelete(fIdleTimer);
delete [] fIdleCommand;
}
}
//______________________________________________________________________________
void TApplication::StartIdleing()
{
// Call when system starts idleing.
if (fIdleTimer) {
fIdleTimer->Reset();
gSystem->AddTimer(fIdleTimer);
}
}
//______________________________________________________________________________
void TApplication::StopIdleing()
{
// Call when system stops idleing.
if (fIdleTimer)
gSystem->RemoveTimer(fIdleTimer);
}
//______________________________________________________________________________
void TApplication::Terminate(int status)
{
// Terminate the application by call TSystem::Exit() unless application has
// been told to return from Run(), by a call to SetReturnFromRun().
if (fReturnFromRun)
gSystem->ExitLoop();
else
gSystem->Exit(status);
}
//______________________________________________________________________________
void TApplication::CreateApplication()
{
// Static function used to create a default application environment.
if (!gApplication) {
new TApplication("RootApp", 0, 0, 0, 0);
Printf("<TApplication::CreateApplication>: "
"created default TApplication");
}
}
ROOT page - Class index - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.