This source file includes following definitions.
- SignalHandler
- GetImageDecoder
- GetImageEncoder
- GetImageMagick
- GetMagickAdjoin
- GetMagickBlobSupport
- GetMagickDescription
- GetMagickEndianSupport
- GetMagickInfo
- MagickInfoCompare
- GetMagickInfoList
- MagickCompare
- GetMagickList
- GetMagickMimeType
- GetMagickPrecision
- GetMagickRawSupport
- GetMagickSeekableStream
- GetMagickThreadSupport
- DestroyMagickNode
- IsMagickTreeInstantiated
- IsMagickConflict
- ListMagickInfo
- IsMagickCoreInstantiated
- MagickComponentGenesis
- MagickComponentTerminus
- SetMagickSignalHandler
- MagickSignalHandler
- RegisterMagickSignalHandler
- MagickCoreGenesis
- MagickCoreTerminus
- RegisterMagickInfo
- SetMagickInfo
- SetMagickPrecision
- UnregisterMagickInfo
#include "magick/studio.h"
#include "magick/annotate.h"
#include "magick/blob.h"
#include "magick/blob-private.h"
#include "magick/cache.h"
#include "magick/coder.h"
#include "magick/client.h"
#include "magick/coder.h"
#include "magick/configure.h"
#include "magick/constitute.h"
#include "magick/delegate.h"
#include "magick/draw.h"
#include "magick/exception.h"
#include "magick/exception-private.h"
#include "magick/locale_.h"
#include "magick/log.h"
#include "magick/magic.h"
#include "magick/magick.h"
#include "magick/memory_.h"
#include "magick/mime.h"
#include "magick/module.h"
#include "magick/nt-base-private.h"
#include "magick/nt-feature.h"
#include "magick/opencl-private.h"
#include "magick/random_.h"
#include "magick/registry.h"
#include "magick/resource_.h"
#include "magick/policy.h"
#include "magick/semaphore.h"
#include "magick/semaphore-private.h"
#include "magick/signature-private.h"
#include "magick/splay-tree.h"
#include "magick/string_.h"
#include "magick/string-private.h"
#include "magick/thread_.h"
#include "magick/thread-private.h"
#include "magick/token.h"
#include "magick/utility.h"
#include "magick/xwindow-private.h"
#if !defined(MAGICKCORE_RETSIGTYPE)
# define MAGICKCORE_RETSIGTYPE void
#endif
#if !defined(SIG_DFL)
# define SIG_DFL ((SignalHandler *) 0)
#endif
#if !defined(SIG_ERR)
# define SIG_ERR ((SignalHandler *) -1)
#endif
#if !defined(SIGMAX)
#define SIGMAX 64
#endif
typedef MAGICKCORE_RETSIGTYPE
SignalHandler(int);
static SemaphoreInfo
*magick_semaphore = (SemaphoreInfo *) NULL;
static SignalHandler
*signal_handlers[SIGMAX] = { (SignalHandler *) NULL };
static SplayTreeInfo
*magick_list = (SplayTreeInfo *) NULL;
static volatile MagickBooleanType
instantiate_magickcore = MagickFalse,
magickcore_signal_in_progress = MagickFalse;
static MagickBooleanType
IsMagickTreeInstantiated(ExceptionInfo *);
MagickExport DecodeImageHandler *GetImageDecoder(const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->decoder);
}
MagickExport EncodeImageHandler *GetImageEncoder(const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->encoder);
}
MagickExport MagickBooleanType GetImageMagick(const unsigned char *magick,
const size_t length,char *format)
{
ExceptionInfo
*exception;
MagickBooleanType
status;
register const MagickInfo
*p;
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick != (const unsigned char *) NULL);
exception=AcquireExceptionInfo();
p=GetMagickInfo("*",exception);
exception=DestroyExceptionInfo(exception);
if (p == (const MagickInfo *) NULL)
return(MagickFalse);
status=MagickFalse;
LockSemaphoreInfo(magick_semaphore);
ResetSplayTreeIterator(magick_list);
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
while (p != (const MagickInfo *) NULL)
{
if ((p->magick != (IsImageFormatHandler *) NULL) &&
(p->magick(magick,length) != 0))
{
status=MagickTrue;
(void) CopyMagickString(format,p->name,MaxTextExtent);
break;
}
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
}
UnlockSemaphoreInfo(magick_semaphore);
return(status);
}
MagickExport MagickBooleanType GetMagickAdjoin(const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->adjoin);
}
MagickExport MagickBooleanType GetMagickBlobSupport(
const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->blob_support);
}
MagickExport const char *GetMagickDescription(const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->description);
}
MagickExport MagickBooleanType GetMagickEndianSupport(
const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->endian_support);
}
MagickExport const MagickInfo *GetMagickInfo(const char *name,
ExceptionInfo *exception)
{
register const MagickInfo
*p;
assert(exception != (ExceptionInfo *) NULL);
if (IsMagickTreeInstantiated(exception) == MagickFalse)
return((const MagickInfo *) NULL);
#if defined(MAGICKCORE_MODULES_SUPPORT)
if ((name != (const char *) NULL) && (LocaleCompare(name,"*") == 0))
(void) OpenModules(exception);
#endif
LockSemaphoreInfo(magick_semaphore);
ResetSplayTreeIterator(magick_list);
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
if ((name == (const char *) NULL) || (LocaleCompare(name,"*") == 0))
{
ResetSplayTreeIterator(magick_list);
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
UnlockSemaphoreInfo(magick_semaphore);
return(p);
}
while (p != (const MagickInfo *) NULL)
{
if (LocaleCompare(p->name,name) == 0)
break;
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
}
#if defined(MAGICKCORE_MODULES_SUPPORT)
if (p == (const MagickInfo *) NULL)
{
if (*name != '\0')
(void) OpenModule(name,exception);
ResetSplayTreeIterator(magick_list);
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
while (p != (const MagickInfo *) NULL)
{
if (LocaleCompare(p->name,name) == 0)
break;
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
}
}
#endif
UnlockSemaphoreInfo(magick_semaphore);
return(p);
}
#if defined(__cplusplus) || defined(c_plusplus)
extern "C" {
#endif
static int MagickInfoCompare(const void *x,const void *y)
{
const MagickInfo
**p,
**q;
p=(const MagickInfo **) x,
q=(const MagickInfo **) y;
return(LocaleCompare((*p)->name,(*q)->name));
}
#if defined(__cplusplus) || defined(c_plusplus)
}
#endif
MagickExport const MagickInfo **GetMagickInfoList(const char *pattern,
size_t *number_formats,ExceptionInfo *exception)
{
const MagickInfo
**formats;
register const MagickInfo
*p;
register ssize_t
i;
assert(pattern != (char *) NULL);
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",pattern);
assert(number_formats != (size_t *) NULL);
*number_formats=0;
p=GetMagickInfo("*",exception);
if (p == (const MagickInfo *) NULL)
return((const MagickInfo **) NULL);
formats=(const MagickInfo **) AcquireQuantumMemory((size_t)
GetNumberOfNodesInSplayTree(magick_list)+1UL,sizeof(*formats));
if (formats == (const MagickInfo **) NULL)
return((const MagickInfo **) NULL);
LockSemaphoreInfo(magick_semaphore);
ResetSplayTreeIterator(magick_list);
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
for (i=0; p != (const MagickInfo *) NULL; )
{
if ((p->stealth == MagickFalse) &&
(GlobExpression(p->name,pattern,MagickFalse) != MagickFalse))
formats[i++]=p;
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
}
UnlockSemaphoreInfo(magick_semaphore);
qsort((void *) formats,(size_t) i,sizeof(*formats),MagickInfoCompare);
formats[i]=(MagickInfo *) NULL;
*number_formats=(size_t) i;
return(formats);
}
#if defined(__cplusplus) || defined(c_plusplus)
extern "C" {
#endif
static int MagickCompare(const void *x,const void *y)
{
register const char
**p,
**q;
p=(const char **) x;
q=(const char **) y;
return(LocaleCompare(*p,*q));
}
#if defined(__cplusplus) || defined(c_plusplus)
}
#endif
MagickExport char **GetMagickList(const char *pattern,
size_t *number_formats,ExceptionInfo *exception)
{
char
**formats;
register const MagickInfo
*p;
register ssize_t
i;
assert(pattern != (char *) NULL);
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",pattern);
assert(number_formats != (size_t *) NULL);
*number_formats=0;
p=GetMagickInfo("*",exception);
if (p == (const MagickInfo *) NULL)
return((char **) NULL);
formats=(char **) AcquireQuantumMemory((size_t)
GetNumberOfNodesInSplayTree(magick_list)+1UL,sizeof(*formats));
if (formats == (char **) NULL)
return((char **) NULL);
LockSemaphoreInfo(magick_semaphore);
ResetSplayTreeIterator(magick_list);
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
for (i=0; p != (const MagickInfo *) NULL; )
{
if ((p->stealth == MagickFalse) &&
(GlobExpression(p->name,pattern,MagickFalse) != MagickFalse))
formats[i++]=ConstantString(p->name);
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
}
UnlockSemaphoreInfo(magick_semaphore);
qsort((void *) formats,(size_t) i,sizeof(*formats),MagickCompare);
formats[i]=(char *) NULL;
*number_formats=(size_t) i;
return(formats);
}
MagickExport const char *GetMagickMimeType(const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->mime_type);
}
MagickExport int GetMagickPrecision(void)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
return(SetMagickPrecision(0));
}
MagickExport MagickBooleanType GetMagickRawSupport(
const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->raw);
}
MagickExport MagickBooleanType GetMagickSeekableStream(
const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->seekable_stream);
}
MagickExport MagickStatusType GetMagickThreadSupport(
const MagickInfo *magick_info)
{
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
return(magick_info->thread_support);
}
static void *DestroyMagickNode(void *magick_info)
{
register MagickInfo
*p;
p=(MagickInfo *) magick_info;
if (p->module != (char *) NULL)
p->module=DestroyString(p->module);
if (p->note != (char *) NULL)
p->note=DestroyString(p->note);
if (p->mime_type != (char *) NULL)
p->mime_type=DestroyString(p->mime_type);
if (p->version != (char *) NULL)
p->version=DestroyString(p->version);
if (p->description != (char *) NULL)
p->description=DestroyString(p->description);
if (p->name != (char *) NULL)
p->name=DestroyString(p->name);
if (p->semaphore != (SemaphoreInfo *) NULL)
DestroySemaphoreInfo(&p->semaphore);
return(RelinquishMagickMemory(p));
}
static MagickBooleanType IsMagickTreeInstantiated(ExceptionInfo *exception)
{
(void) exception;
if (magick_list == (SplayTreeInfo *) NULL)
{
if (magick_semaphore == (SemaphoreInfo *) NULL)
ActivateSemaphoreInfo(&magick_semaphore);
LockSemaphoreInfo(magick_semaphore);
if (magick_list == (SplayTreeInfo *) NULL)
{
MagickBooleanType
status;
MagickInfo
*magick_info;
magick_list=NewSplayTree(CompareSplayTreeString,(void *(*)(void *))
NULL,DestroyMagickNode);
if (magick_list == (SplayTreeInfo *) NULL)
ThrowFatalException(ResourceLimitFatalError,
"MemoryAllocationFailed");
magick_info=SetMagickInfo("ephemeral");
magick_info->stealth=MagickTrue;
status=AddValueToSplayTree(magick_list,magick_info->name,magick_info);
if (status == MagickFalse)
ThrowFatalException(ResourceLimitFatalError,
"MemoryAllocationFailed");
magick_info=SetMagickInfo("clipmask");
magick_info->stealth=MagickTrue;
status=AddValueToSplayTree(magick_list,magick_info->name,magick_info);
if (status == MagickFalse)
ThrowFatalException(ResourceLimitFatalError,
"MemoryAllocationFailed");
#if defined(MAGICKCORE_MODULES_SUPPORT)
(void) GetModuleInfo((char *) NULL,exception);
#endif
#if !defined(MAGICKCORE_BUILD_MODULES)
RegisterStaticModules();
#endif
}
UnlockSemaphoreInfo(magick_semaphore);
}
return(magick_list != (SplayTreeInfo *) NULL ? MagickTrue : MagickFalse);
}
MagickExport MagickBooleanType IsMagickConflict(const char *magick)
{
assert(magick != (char *) NULL);
#if defined(macintosh)
return(MACIsMagickConflict(magick));
#elif defined(vms)
return(VMSIsMagickConflict(magick));
#elif defined(MAGICKCORE_WINDOWS_SUPPORT)
return(NTIsMagickConflict(magick));
#else
return(MagickFalse);
#endif
}
MagickExport MagickBooleanType ListMagickInfo(FILE *file,
ExceptionInfo *exception)
{
const MagickInfo
**magick_info;
register ssize_t
i;
size_t
number_formats;
ssize_t
j;
if (file == (FILE *) NULL)
file=stdout;
magick_info=GetMagickInfoList("*",&number_formats,exception);
if (magick_info == (const MagickInfo **) NULL)
return(MagickFalse);
ClearMagickException(exception);
#if !defined(MAGICKCORE_MODULES_SUPPORT)
(void) FormatLocaleFile(file," Format Mode Description\n");
#else
(void) FormatLocaleFile(file," Format Module Mode Description\n");
#endif
(void) FormatLocaleFile(file,
"--------------------------------------------------------"
"-----------------------\n");
for (i=0; i < (ssize_t) number_formats; i++)
{
if (magick_info[i]->stealth != MagickFalse)
continue;
(void) FormatLocaleFile(file,"%9s%c ",
magick_info[i]->name != (char *) NULL ? magick_info[i]->name : "",
magick_info[i]->blob_support != MagickFalse ? '*' : ' ');
#if defined(MAGICKCORE_MODULES_SUPPORT)
{
char
module[MaxTextExtent];
*module='\0';
if (magick_info[i]->module != (char *) NULL)
(void) CopyMagickString(module,magick_info[i]->module,MaxTextExtent);
(void) ConcatenateMagickString(module," ",MaxTextExtent);
module[9]='\0';
(void) FormatLocaleFile(file,"%9s ",module);
}
#endif
(void) FormatLocaleFile(file,"%c%c%c ",magick_info[i]->decoder ? 'r' : '-',
magick_info[i]->encoder ? 'w' : '-',magick_info[i]->encoder != NULL &&
magick_info[i]->adjoin != MagickFalse ? '+' : '-');
if (magick_info[i]->description != (char *) NULL)
(void) FormatLocaleFile(file," %s",magick_info[i]->description);
if (magick_info[i]->version != (char *) NULL)
(void) FormatLocaleFile(file," (%s)",magick_info[i]->version);
(void) FormatLocaleFile(file,"\n");
if (magick_info[i]->note != (char *) NULL)
{
char
**text;
text=StringToList(magick_info[i]->note);
if (text != (char **) NULL)
{
for (j=0; text[j] != (char *) NULL; j++)
{
(void) FormatLocaleFile(file," %s\n",text[j]);
text[j]=DestroyString(text[j]);
}
text=(char **) RelinquishMagickMemory(text);
}
}
}
(void) FormatLocaleFile(file,"\n* native blob support\n");
(void) FormatLocaleFile(file,"r read support\n");
(void) FormatLocaleFile(file,"w write support\n");
(void) FormatLocaleFile(file,"+ support for multiple images\n");
(void) fflush(file);
magick_info=(const MagickInfo **) RelinquishMagickMemory((void *)
magick_info);
return(MagickTrue);
}
MagickExport MagickBooleanType IsMagickCoreInstantiated(void)
{
return(instantiate_magickcore);
}
MagickExport MagickBooleanType MagickComponentGenesis(void)
{
if (magick_semaphore == (SemaphoreInfo *) NULL)
magick_semaphore=AllocateSemaphoreInfo();
return(MagickTrue);
}
MagickExport void MagickComponentTerminus(void)
{
if (magick_semaphore == (SemaphoreInfo *) NULL)
ActivateSemaphoreInfo(&magick_semaphore);
LockSemaphoreInfo(magick_semaphore);
if (magick_list != (SplayTreeInfo *) NULL)
magick_list=DestroySplayTree(magick_list);
UnlockSemaphoreInfo(magick_semaphore);
DestroySemaphoreInfo(&magick_semaphore);
}
static SignalHandler *SetMagickSignalHandler(int signal_number,
SignalHandler *handler)
{
#if defined(MAGICKCORE_HAVE_SIGACTION) && defined(MAGICKCORE_HAVE_SIGEMPTYSET)
int
status;
sigset_t
mask;
struct sigaction
action,
previous_action;
sigemptyset(&mask);
sigaddset(&mask,signal_number);
sigprocmask(SIG_BLOCK,&mask,NULL);
action.sa_mask=mask;
action.sa_handler=handler;
action.sa_flags=0;
#if defined(SA_INTERRUPT)
action.sa_flags|=SA_INTERRUPT;
#endif
status=sigaction(signal_number,&action,&previous_action);
if (status < 0)
return(SIG_ERR);
sigprocmask(SIG_UNBLOCK,&mask,NULL);
return(previous_action.sa_handler);
#else
return(signal(signal_number,handler));
#endif
}
static void MagickSignalHandler(int signal_number)
{
if (magickcore_signal_in_progress != MagickFalse)
(void) SetMagickSignalHandler(signal_number,signal_handlers[signal_number]);
magickcore_signal_in_progress=MagickTrue;
AsynchronousResourceComponentTerminus();
#if defined(SIGQUIT)
if (signal_number == SIGQUIT)
abort();
#endif
#if defined(SIGABRT)
if (signal_number == SIGABRT)
abort();
#endif
#if defined(SIGFPE)
if (signal_number == SIGFPE)
abort();
#endif
#if defined(SIGXCPU)
if (signal_number == SIGXCPU)
abort();
#endif
#if defined(SIGXFSZ)
if (signal_number == SIGXFSZ)
abort();
#endif
#if defined(SIGSEGV)
if (signal_number == SIGSEGV)
abort();
#endif
#if !defined(MAGICKCORE_HAVE__EXIT)
exit(signal_number);
#else
#if defined(SIGHUP)
if (signal_number == SIGHUP)
exit(signal_number);
#endif
#if defined(SIGINT)
if (signal_number == SIGINT)
exit(signal_number);
#endif
#if defined(SIGTERM)
if (signal_number == SIGTERM)
exit(signal_number);
#endif
#if defined(MAGICKCORE_HAVE_RAISE)
if (signal_handlers[signal_number] != MagickSignalHandler)
raise(signal_number);
#endif
_exit(signal_number);
#endif
}
static SignalHandler *RegisterMagickSignalHandler(int signal_number)
{
SignalHandler
*handler;
handler=SetMagickSignalHandler(signal_number,MagickSignalHandler);
if (handler == SIG_ERR)
return(handler);
if (handler != SIG_DFL)
handler=SetMagickSignalHandler(signal_number,handler);
else
(void) LogMagickEvent(ConfigureEvent,GetMagickModule(),
"Register handler for signal: %d",signal_number);
return(handler);
}
MagickExport void MagickCoreGenesis(const char *path,
const MagickBooleanType establish_signal_handlers)
{
char
*events,
execution_path[MaxTextExtent],
filename[MaxTextExtent];
InitializeMagickMutex();
LockMagickMutex();
if (instantiate_magickcore != MagickFalse)
{
UnlockMagickMutex();
return;
}
(void) SemaphoreComponentGenesis();
(void) LogComponentGenesis();
(void) LocaleComponentGenesis();
(void) RandomComponentGenesis();
events=GetEnvironmentValue("MAGICK_DEBUG");
if (events != (char *) NULL)
{
(void) SetLogEventMask(events);
events=DestroyString(events);
}
#if defined(MAGICKCORE_WINDOWS_SUPPORT)
NTWindowsGenesis();
#endif
#if defined(MAGICKCORE_WINDOWS_SUPPORT)
if ((path != (const char *) NULL) && (IsPathAccessible(path) != MagickFalse))
#else
if ((path != (const char *) NULL) && (*path == *DirectorySeparator) &&
(IsPathAccessible(path) != MagickFalse))
#endif
(void) CopyMagickString(execution_path,path,MaxTextExtent);
else
(void) GetExecutionPath(execution_path,MaxTextExtent);
GetPathComponent(execution_path,TailPath,filename);
(void) SetClientName(filename);
GetPathComponent(execution_path,HeadPath,execution_path);
(void) SetClientPath(execution_path);
if (establish_signal_handlers != MagickFalse)
{
#if defined(SIGABRT)
if (signal_handlers[SIGABRT] == (SignalHandler *) NULL)
signal_handlers[SIGABRT]=RegisterMagickSignalHandler(SIGABRT);
#endif
#if defined(SIGSEGV)
if (signal_handlers[SIGSEGV] == (SignalHandler *) NULL)
signal_handlers[SIGSEGV]=RegisterMagickSignalHandler(SIGSEGV);
#endif
#if defined(SIGFPE)
if (signal_handlers[SIGFPE] == (SignalHandler *) NULL)
signal_handlers[SIGFPE]=RegisterMagickSignalHandler(SIGFPE);
#endif
#if defined(SIGHUP)
if (signal_handlers[SIGHUP] == (SignalHandler *) NULL)
signal_handlers[SIGHUP]=RegisterMagickSignalHandler(SIGHUP);
#endif
#if defined(SIGINT)
if (signal_handlers[SIGINT] == (SignalHandler *) NULL)
signal_handlers[SIGINT]=RegisterMagickSignalHandler(SIGINT);
#endif
#if defined(SIGQUIT)
if (signal_handlers[SIGQUIT] == (SignalHandler *) NULL)
signal_handlers[SIGQUIT]=RegisterMagickSignalHandler(SIGQUIT);
#endif
#if defined(SIGTERM)
if (signal_handlers[SIGTERM] == (SignalHandler *) NULL)
signal_handlers[SIGTERM]=RegisterMagickSignalHandler(SIGTERM);
#endif
#if defined(SIGXCPU)
if (signal_handlers[SIGXCPU] == (SignalHandler *) NULL)
signal_handlers[SIGXCPU]=RegisterMagickSignalHandler(SIGXCPU);
#endif
#if defined(SIGXFSZ)
if (signal_handlers[SIGXFSZ] == (SignalHandler *) NULL)
signal_handlers[SIGXFSZ]=RegisterMagickSignalHandler(SIGXFSZ);
#endif
}
(void) ConfigureComponentGenesis();
(void) PolicyComponentGenesis();
(void) CacheComponentGenesis();
(void) ResourceComponentGenesis();
(void) CoderComponentGenesis();
(void) MagickComponentGenesis();
#if defined(MAGICKCORE_MODULES_SUPPORT)
(void) ModuleComponentGenesis();
#endif
(void) DelegateComponentGenesis();
(void) MagicComponentGenesis();
(void) ColorComponentGenesis();
(void) TypeComponentGenesis();
(void) MimeComponentGenesis();
(void) AnnotateComponentGenesis();
#if defined(MAGICKCORE_X11_DELEGATE)
(void) XComponentGenesis();
#endif
(void) RegistryComponentGenesis();
instantiate_magickcore=MagickTrue;
UnlockMagickMutex();
}
MagickExport void MagickCoreTerminus(void)
{
InitializeMagickMutex();
LockMagickMutex();
if (instantiate_magickcore == MagickFalse)
{
UnlockMagickMutex();
return;
}
RegistryComponentTerminus();
#if defined(MAGICKCORE_X11_DELEGATE)
XComponentTerminus();
#endif
AnnotateComponentTerminus();
MimeComponentTerminus();
TypeComponentTerminus();
OpenCLTerminus();
ColorComponentTerminus();
#if defined(MAGICKCORE_WINDOWS_SUPPORT)
NTWindowsTerminus();
#endif
MagicComponentTerminus();
DelegateComponentTerminus();
MagickComponentTerminus();
#if !defined(MAGICKCORE_BUILD_MODULES)
UnregisterStaticModules();
#endif
#if defined(MAGICKCORE_MODULES_SUPPORT)
ModuleComponentTerminus();
#endif
CoderComponentTerminus();
ResourceComponentTerminus();
CacheComponentTerminus();
PolicyComponentTerminus();
ConfigureComponentTerminus();
RandomComponentTerminus();
LocaleComponentTerminus();
LogComponentTerminus();
SemaphoreComponentTerminus();
instantiate_magickcore=MagickFalse;
UnlockMagickMutex();
DestroyMagickMutex();
}
MagickExport MagickInfo *RegisterMagickInfo(MagickInfo *magick_info)
{
MagickBooleanType
status;
assert(magick_info != (MagickInfo *) NULL);
assert(magick_info->signature == MagickSignature);
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",magick_info->name);
if (magick_list == (SplayTreeInfo *) NULL)
return((MagickInfo *) NULL);
if (((magick_info->thread_support & DecoderThreadSupport) == 0) ||
((magick_info->thread_support & EncoderThreadSupport) == 0))
magick_info->semaphore=AllocateSemaphoreInfo();
status=AddValueToSplayTree(magick_list,magick_info->name,magick_info);
if (status == MagickFalse)
ThrowFatalException(ResourceLimitFatalError,"MemoryAllocationFailed");
return(magick_info);
}
MagickExport MagickInfo *SetMagickInfo(const char *name)
{
MagickInfo
*magick_info;
assert(name != (const char *) NULL);
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"%s",name);
magick_info=(MagickInfo *) AcquireMagickMemory(sizeof(*magick_info));
if (magick_info == (MagickInfo *) NULL)
ThrowFatalException(ResourceLimitFatalError,"MemoryAllocationFailed");
(void) ResetMagickMemory(magick_info,0,sizeof(*magick_info));
magick_info->name=ConstantString(name);
magick_info->adjoin=MagickTrue;
magick_info->blob_support=MagickTrue;
magick_info->thread_support=(MagickStatusType) (DecoderThreadSupport |
EncoderThreadSupport);
magick_info->signature=MagickSignature;
return(magick_info);
}
MagickExport int SetMagickPrecision(const int precision)
{
#define MagickPrecision 6
static int
magick_precision = 0;
(void) LogMagickEvent(TraceEvent,GetMagickModule(),"...");
if (precision > 0)
magick_precision=precision;
if ((precision < 0) || (magick_precision == 0))
{
char
*limit;
magick_precision = MagickPrecision;
limit=GetEnvironmentValue("MAGICK_PRECISION");
if (limit == (char *) NULL)
limit=GetPolicyValue("precision");
if (limit != (char *) NULL)
{
magick_precision=StringToInteger(limit);
limit=DestroyString(limit);
}
}
return(magick_precision);
}
MagickExport MagickBooleanType UnregisterMagickInfo(const char *name)
{
register const MagickInfo
*p;
MagickBooleanType
status;
assert(name != (const char *) NULL);
if (magick_list == (SplayTreeInfo *) NULL)
return(MagickFalse);
if (GetNumberOfNodesInSplayTree(magick_list) == 0)
return(MagickFalse);
LockSemaphoreInfo(magick_semaphore);
ResetSplayTreeIterator(magick_list);
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
while (p != (const MagickInfo *) NULL)
{
if (LocaleCompare(p->name,name) == 0)
break;
p=(const MagickInfo *) GetNextValueInSplayTree(magick_list);
}
status=DeleteNodeByValueFromSplayTree(magick_list,p);
UnlockSemaphoreInfo(magick_semaphore);
return(status);
}