108 TTHREAD_TLS(
bool) readingDirs (
false);
118 const char *className,
const char *pluginName,
119 const char *ctor,
const char *origin):
132 TString aclicMode, arguments, io;
193 using exit_scope = std::shared_ptr<void*>;
194 exit_scope guard(
nullptr,
195 [
this,&setCanCall](
void *) { this->
fCanCall = setCanCall; } );
200 Error(
"SetupCallEnv",
"class %s not found in plugin %s",
fClass.
Data(),
218 Error(
"SetupCallEnv",
"global function %s not found", method.
Data());
220 Error(
"SetupCallEnv",
"method %s not found in class %s", method.
Data(),
226 Error(
"SetupCallEnv",
"method %s is not public", method.
Data());
273 Error(
"ExecPlugin",
"no ctor specified for this handler %s",
fClass.
Data());
296 Error(
"ExecPlugin",
"nargs (%d) not consistent with expected number of arguments ([%d-%d])",
311 const char *exist =
"";
317 if (strchr(opt,
'a')) {
323 if (path)
Printf(
" [Lib: %s]", path);
358 while ((er = (
TEnvRec*) next())) {
360 if ((
s = strstr(er->
GetName(),
"Plugin."))) {
364 const char *val = env->
GetValue(
s, (
const char*)0);
371 if (regexp.
IsNull())
break;
372 TString clss = strtok(0,
"; ");
374 TString plugin = strtok(0,
"; ");
375 if (plugin.
IsNull())
break;
376 TString ctor = strtok(0,
";\"");
378 ctor = strtok(0,
";\"");
396 Info(
"LoadHandlerMacros",
"%s", path);
402 if (
f[0] ==
'P' &&
f.EndsWith(
".C")) {
415 Info(
"LoadHandlerMacros",
" plugin macro: %s",
s->String().Data());
418 Error(
"LoadHandlerMacros",
"pluging macro %s returned %ld",
419 s->String().Data(), res);
477 if (plugindirs.
Length() == 0) {
478 plugindirs =
"plugins";
491 for (
Int_t j = 0; j < i; j++) {
507 Info(
"LoadHandlersFromPluginDirs",
"%s",
d.Data());
530 const char *className,
const char *pluginName,
531 const char *ctor,
const char *origin)
547 pluginName, ctor, origin);
567 if (
h->fBase == base) {
568 if (!regexp ||
h->fRegexp == regexp) {
590 if (
h->CanHandle(base, uri)) {
592 Info(
"FindHandler",
"found plugin for %s",
h->GetClass());
599 Info(
"FindHandler",
"did not find plugin for class %s and uri %s", base, uri);
601 Info(
"FindHandler",
"did not find plugin for class %s", base);
619 Printf(
"=====================================================================");
620 Printf(
"Base Regexp Class Plugin");
621 Printf(
"=====================================================================");
626 if (
h->CheckPlugin() == -1)
629 Printf(
"=====================================================================");
630 Printf(
"%d plugin handlers registered",
cnt);
631 Printf(
"[*] %d %s not available", cntmiss, cntmiss==1 ?
"plugin" :
"plugins");
632 Printf(
"=====================================================================\n");
654 Error(
"WritePluginMacros",
"cannot write in directory %s",
d.Data());
664 if (plugin && strcmp(plugin,
h->fBase) && strcmp(plugin,
h->fClass)) {
668 if (base !=
h->fBase) {
679 Error(
"WritePluginMacros",
"cannot create directory %s", sdd.
Data());
684 fn.
Form(
"P%03d_%s.C", idx,
h->fClass.Data());
686 FILE *
f = fopen(fd,
"w");
688 fprintf(
f,
"void P%03d_%s()\n{\n", idx,
h->fClass.Data());
689 fprintf(
f,
" gPluginMgr->AddHandler(\"%s\", \"%s\", \"%s\",\n",
690 h->fBase.Data(),
h->fRegexp.Data(),
h->fClass.Data());
691 fprintf(
f,
" \"%s\", \"%s\");\n",
h->fPlugin.Data(),
h->fCtor.Data());
701 fprintf(
f,
" gPluginMgr->AddHandler(\"%s\", \"%s\", \"%s\",\n",
732 if (!envFile || !envFile[0])
735 fd = fopen(envFile,
"w+");
738 Error(
"WritePluginRecords",
"error opening file %s", envFile);
748 if (plugin && strcmp(plugin,
h->fBase) && strcmp(plugin,
h->fClass)) {
752 if (base !=
h->fBase) {
761 fprintf(fd,
"Plugin.%s: %s %s %s \"%s\"\n", base2.
Data(),
h->fRegexp.Data(),
762 h->fClass.Data(),
h->fPlugin.Data(),
h->fCtor.Data());
764 fprintf(fd,
"+Plugin.%s: %s %s %s \"%s\"\n", base2.
Data(),
h->fRegexp.Data(),
765 h->fClass.Data(),
h->fPlugin.Data(),
h->fCtor.Data());
775 fprintf(fd,
"+Plugin.%s: %s %s %s \"%s\"\n", base2.
Data(), h2->
fRegexp.
Data(),
784 if (envFile && envFile[0])
R__EXTERN TVirtualMutex * gInterpreterMutex
static bool & TPH__IsReadingDirs()
TPluginManager * gPluginMgr
static TVirtualMutex * gPluginManagerMutex
void Printf(const char *fmt,...)
char * StrDup(const char *str)
Duplicate the string str.
R__EXTERN TSystem * gSystem
#define R__LOCKGUARD2(mutex)
#define R__LOCKGUARD(mutex)
#define R__WRITE_LOCKGUARD(mutex)
#define R__READ_LOCKGUARD(mutex)
TClass instances represent classes, structs and namespaces in the ROOT type system.
static TClass * LoadClass(const char *requestedname, Bool_t silent)
Helper function used by TClass::GetClass().
static TClass * GetClass(const char *name, Bool_t load=kTRUE, Bool_t silent=kFALSE)
Static method returning pointer to TClass of the specified class name.
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
const char * GetName() const
Returns name of object.
The TEnv class reads config files, by default named .rootrc.
virtual Int_t GetValue(const char *name, Int_t dflt) const
Returns the integer value for a resource.
THashList * GetTable() const
Long_t Property() const
Get property description word. For meaning of bits see EProperty.
Int_t GetNargsOpt() const
Number of function optional (default) arguments.
Int_t GetNargs() const
Number of function arguments.
THashTable implements a hash table to store TObject's.
void Add(TObject *obj)
Add object to the hash table.
TObject * FindObject(const char *name) const
Find object using its name.
virtual void Add(TObject *obj)
virtual TObject * Remove(TObject *obj)
Remove object from the list.
virtual TObjLink * FirstLink() const
Method or function calling interface.
void Init(const TFunction *func)
Initialize the method invocation environment based on the TFunction object.
Int_t GetEntriesFast() const
TObject * At(Int_t idx) const
Wrapper around a TObject so it can be stored in a TList.
TObject * GetObject() const
Collectable string class.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual void Info(const char *method, const char *msgfmt,...) const
Issue info message.
Int_t CheckPlugin() const
Check if the plugin library for this handler exits.
void Print(Option_t *opt="") const
Print info about the plugin handler.
TFunction * fMethod
ctor method call environment
AtomicInt_t fCanCall
ctor method or global function
Bool_t CanHandle(const char *base, const char *uri)
Check if regular expression appears in the URI, if so return kTRUE.
~TPluginHandler()
Cleanup plugin handler object.
Bool_t CheckForExecPlugin(Int_t nargs)
Check that we can properly run ExecPlugin.
Bool_t fIsMacro
if 1 fCallEnv is ok, -1 fCallEnv is not ok, 0 fCallEnv not setup yet.
void SetupCallEnv()
Setup ctor or static method call environment.
Int_t LoadPlugin()
Load the plugin library for this handler.
This class implements a plugin library manager.
void LoadHandlersFromPluginDirs(const char *base=0)
Load plugin handlers specified via macros in a list of plugin directories.
void AddHandler(const char *base, const char *regexp, const char *className, const char *pluginName, const char *ctor=0, const char *origin=0)
Add plugin handler to the list of handlers.
~TPluginManager()
Clean up the plugin manager.
TPluginHandler * FindHandler(const char *base, const char *uri=0)
Returns the handler if there exists a handler for the specified URI.
void Print(Option_t *opt="") const
Print list of registered plugin handlers.
void LoadHandlersFromEnv(TEnv *env)
Load plugin handlers specified in config file, like:
void RemoveHandler(const char *base, const char *regexp=0)
Remove handler for the specified base class and the specified regexp.
THashTable * fBasesLoaded
void LoadHandlerMacros(const char *path)
Load all plugin macros from the specified path/base directory.
Int_t WritePluginMacros(const char *dir, const char *plugin=0) const
Write in the specified directory the plugin macros.
Int_t WritePluginRecords(const char *envFile, const char *plugin=0) const
Write in the specified environment config file the plugin records.
static const TString & GetEtcDir()
Get the sysconfig directory in the installation. Static utility function.
Regular expression class.
A sorted doubly linked list.
void Add(TObject *obj)
Add object in sorted list.
Bool_t EndsWith(const char *pat, ECaseCompare cmp=kExact) const
Return true if string ends with the specified string.
TSubString Strip(EStripType s=kTrailing, char c=' ') const
Return a substring of self stripped at beginning and/or end.
const char * Data() const
Bool_t MaybeRegexp() const
Returns true if string contains one of the regexp characters "^$.[]*+?".
TString & ReplaceAll(const TString &s1, const TString &s2)
TObjArray * Tokenize(const TString &delim) const
This function is used to isolate sequential tokens in a TString.
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
virtual void FreeDirectory(void *dirp)
Free a directory.
virtual void * OpenDirectory(const char *name)
Open a directory. Returns 0 if directory does not exist.
virtual TString SplitAclicMode(const char *filename, TString &mode, TString &args, TString &io) const
This method split a filename of the form:
virtual char * ConcatFileName(const char *dir, const char *name)
Concatenate a directory and a file name. User must delete returned string.
virtual int MakeDirectory(const char *name)
Make a directory.
virtual const char * PrependPathName(const char *dir, TString &name)
Concatenate a directory and a file name.
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
Returns FALSE if one can access a file using the specified access mode.
virtual const char * GetDirEntry(void *dirp)
Get a directory entry. Returns 0 if no more entries.
char * DynamicPathName(const char *lib, Bool_t quiet=kFALSE)
Find a dynamic library called lib using the system search paths.
This class implements a mutex interface.
R__EXTERN TVirtualRWMutex * gCoreMutex
static constexpr double s