NAME

utility - ImageMagick Utility Methods


SYNOPSIS

char * AllocateString( const char *source );

void AppendImageFormat( const char *format, char *filename );

BaseFilename( name );

unsigned int CloneString( char ** destination, const char *source );

unicode= ConvertTextToUnicode( text, count );

ExpandFilename( filename );

status= ExpandFilenames( argc, argv );

void FormatString( char *string, const char *format, ... );

int GetGeometry( const char *image_geometry, int *x, int *y, unsigned int *width, unsigned int *height );

GlobExpression( expression, pattern );

unsigned int IsAccessible( const char *filename );

unsigned int IsDirectory( const char *filename );

int Latin1Compare( const char *p, const char *q );

filelist= ListColors( pattern, number_colors );

filelist= ListFiles( directory, pattern, number_entries );

void LocaleFilename( char *filename );

int MultilineCensus( const char *label );

int ParseGeometry( const char *geometry, int *x, int *y, unsigned int *width, unsigned int *height );

void Destroy PostscriptGeometry( char *geometry );

char * SetClientName( const char *name );

char ** StringToArgv( const char *text, int *argc );

char ** StringToList( const char *text );

void Strip( char *data );

int SystemCommand( const unsigned int verbose, const char *command );

void TemporaryFilename( char *filename );

char * TranslateText( const ImageInfo *image_info, const Image *image, const char *formatted_text );


FUNCTION DESCRIPTIONS


AllocateString

Method AllocateString allocates memory for a string and copies the source string to that memory location (and returns it).

The format of the AllocateString method is:

char *AllocateString ( const char *source );

A description of each parameter follows:

allocated_string:

Method AllocateString returns a copy of the source string.

source:

A character string.


AppendImageFormat

Method AppendImageFormat appends the image format type to the filename. If an extension to the file already exists, it is first removed.

The format of the AppendImageFormat method is:

void AppendImageFormat ( const char *format, char *filename );

A description of each parameter follows.

format:

Specifies a pointer to an array of characters. This is the format of the image.

filename:

Specifies a pointer to an array of characters. The unique file name is returned in this array.


BaseFilename

Method BaseFilename removes the path name component and any extensions.

The format of the BaseFilename function is:

BaseFilename ( name );

A description of each parameter follows:

name:

Specifies a pointer to a character array that contains the name.


CloneString

Method CloneString allocates memory for the destination string and copies the source string to that memory location.

The format of the (void) CloneString method is:

unsigned int CloneString ( char **destination, const char *source );

A description of each parameter follows:

status:

Method CloneString returns True is the string is cloned, otherwise False is returned.

destination:

A pointer to a character string.

source:

A character string.


ConvertTextToUnicode

Method ConvertTextToUnicode converts an ASCII text string to Unicode and returns the Unicode translation and the character count. Normal characters are just copied. However, escaped hex codes are interpreted before converting to Unicode (e.g. \0x30a3 is 12451 in the Unicode character set).

The format of the ConvertTextToUnicode function is:

unicode=ConvertTextToUnicode ( text, count );

A description of each parameter follows:

unicode:

Method ConvertTextToUnicode returns a pointer to an unsigned short array representing the Unicode translation of the ASCII string.

text:

Specifies a pointer to a character array that contains the text to convert.

count:

The number of characters that were translated from ASCII to Unicode is returned in this unsigned integer pointer.


ExpandFilename

Method ExpandFilename expands '~' in a filename.

The format of the ExpandFilename function is:

ExpandFilename ( filename );

A description of each parameter follows:

filename:

Specifies a pointer to a character array that contains the filename.


ExpandFilenames

Method ExpandFilenames checks each argument of the command line vector and expands it if they have a wildcard character. For example, *.jpg might expand to: bird.jpg rose.jpg tiki.jpg.

The format of the ExpandFilenames function is:

status=ExpandFilenames ( argc, argv );

A description of each parameter follows:

argc:

Specifies a pointer to an integer describing the number of elements in the argument vector.

argv:

Specifies a pointer to a text array containing the command line arguments.


FormatString

Method FormatString prints formatted output of a variable argument list.

The format of the FormatString method is:

void FormatString ( char *string, const char *format, ... );

A description of each parameter follows.

string:

Method FormatString returns the formatted string in this character buffer.

format:

A string describing the format to use to write the remaining arguments.


GetGeometry

Method GetGeometry parses a geometry specification and returns the width, height, x, and y values. It also returns flags that indicates which of the four values (width, height, xoffset, yoffset) were located in the string, and whether the x and y values are negative. In addition,

The format of the GetGeometry method is:

int GetGeometry ( const char *image_geometry, int *x, int *y, unsigned int *width, unsigned int *height );

A description of each parameter follows:

flags:

Method GetGeometry returns a bitmask that indicates which of the four values were located in the geometry string.

image_geometry:

Specifies a character string representing the geometry specification.

x,y:

A pointer to an integer. The x and y offset as determined by the geometry specification is returned here.

width,height:

A pointer to an unsigned integer. The width and height as determined by the geometry specification is returned here.


GlobExpression

Method GlobExpression returns True if the expression matches the pattern.

The format of the GlobExpression function is:

GlobExpression ( expression, pattern );

A description of each parameter follows:

expression:

Specifies a pointer to a text string containing a file name.

pattern:

Specifies a pointer to a text string containing a pattern.


IsAccessible

Method IsAccessible returns True if the file as defined by filename is accessible.

The format of the IsAccessible method is:

unsigned int IsAccessible ( const char *filename );

A description of each parameter follows.

status:

Method IsAccessible returns True is the file as defined by filename is accessible, otherwise False is returned.

filename:

Specifies a pointer to an array of characters. The unique file name is returned in this array.


IsDirectory

Method IsDirectory returns True if the file as defined by filename is a directory. Once MetroWerks write a stat(2) function, we can remove the chdir(2) function.

The format of the IsAccessible method is:

unsigned int IsDirectory ( const char *filename );

A description of each parameter follows.

status:

Method IsDirectory returns True is the file as defined by filename is a directory, otherwise False is returned.

filename:

Specifies a pointer to an array of characters. The unique file name is returned in this array.


Latin1Compare

Method Latin1Compare compares two null terminated Latin-1 strings, ignoring case differences, and returns an integer greater than, equal to, or less than 0, according to whether first is lexicographically greater than, equal to, or less than second. The two strings are assumed to be encoded using ISO 8859-1.

The format of the Latin1Compare method is:

int Latin1Compare ( const char *p, const char *q );

A description of each parameter follows:

p:

A pointer to the string to convert to Latin1 string.

q:

A pointer to the string to convert to Latin1 string.


ListColors

Method ListColors reads the X client color database and returns a list of colors contained in the database sorted in ascending alphabetic order.

The format of the ListColors function is:

filelist=ListColors ( pattern, number_colors );

A description of each parameter follows:

filelist:

Method ListColors returns a list of colors contained in the database. If the database cannot be read, a NULL list is returned.

pattern:

Specifies a pointer to a text string containing a pattern.

number_colors:

This integer returns the number of colors in the list.


ListFiles

Method ListFiles reads the directory specified and returns a list of filenames contained in the directory sorted in ascending alphabetic order.

The format of the ListFiles function is:

filelist=ListFiles ( directory, pattern, number_entries );

A description of each parameter follows:

filelist:

Method ListFiles returns a list of filenames contained in the directory. If the directory specified cannot be read or it is a file a NULL list is returned.

directory:

Specifies a pointer to a text string containing a directory name.

pattern:

Specifies a pointer to a text string containing a pattern.

number_entries:

This integer returns the number of filenames in the list.


LocaleFilename

Method LocaleFilename replaces the contents of the string pointed to by filename by a unique file name relative to the directory.

The format of the LocaleFilename method is:

void LocaleFilename ( char *filename );

A description of each parameter follows.

filename:

Specifies a pointer to an array of characters. The unique file name is returned in this array.


MultilineCensus

Method MultilineCensus returns the number of lines within a label. A line is represented by a \n character.

The format of the MultilineCenus method is:

int MultilineCensus ( const char *label );

A description of each parameter follows.

label:

This character string is the label.


ParseGeometry

Method ParseImageGeometry parses a geometry specification and returns the width, height, x, and y values. It also returns flags that indicates which of the four values (width, height, xoffset, yoffset) were located in the string, and whether the x and y values are negative. In addition,

The format of the ParseImageGeometry method is:

int ParseGeometry ( const char *geometry, int *x, int *y, unsigned int *width, unsigned int *height );

A description of each parameter follows:

flags:

Method ParseImageGeometry returns a bitmask that indicates which of the four values were located in the geometry string.

image_geometry:

Specifies a character string representing the geometry specification.

x,y:

A pointer to an integer. The x and y offset as determined by the geometry specification is returned here.

width,height:

A pointer to an unsigned integer. The width and height as determined by the geometry specification is returned here.


PostscriptGeometry

Method PostscriptGeometry replaces any page mneumonic with the equivalent size in picas.

The format of the PostscriptGeometry method is:

void DestroyPostscriptGeometry ( char *geometry );

A description of each parameter follows.

page:

Specifies a pointer to an array of characters. The string is either a Postscript page name (e.g. A4) or a postscript page geometry (e.g. 612x792+36+36).


SetClientName

Method SetClientName sets the client name if the name is specified. Otherwise the current client name is returned.

The format of the SetClientName method is:

char *SetClientName ( const char *name );

A description of each parameter follows:

client_name:

Method SetClientName returns the current client name.

status:

Specifies the new client name.


StringToArgv

Method StringToArgv converts a text string into command line arguments.

The format of the StringToArgv method is:

char **StringToArgv ( const char *text, int *argc );

A description of each parameter follows:

argv:

Method StringToArgv returns the string list unless an error occurs, otherwise NULL.

text:

Specifies the string to segment into a list.

argc:

This integer pointer returns the number of arguments in the list.


StringToList

Method StringToList converts a text string into a list by segmenting the text string at each carriage return discovered. The list is converted to HEX characters if any control characters are discovered within the text string.

The format of the StringToList method is:

char **StringToList ( const char *text );

A description of each parameter follows:

list:

Method StringToList returns the string list unless an error occurs, otherwise NULL.

text:

Specifies the string to segment into a list.


Strip

Method Strip strips the whitespace from the beginning and end of a string of characters.

The format of the Strip method is:

void Strip ( char *data );

A description of each parameter follows:

data:

Specifies an array of characters.


SystemCommand

Method SystemCommand executes the specified command and waits until it terminates. The returned value is the exit status of the command.

The format of the SystemCommand method is:

int SystemCommand ( const unsigned int verbose, const char *command );

A description of each parameter follows:

status:

Method SystemCommand returns False if the command is executed successfully.

verbose:

An unsigned integer other than 0 prints the executed command before it is invoked.

command:

This string is the command to execute.


TemporaryFilename

Method TemporaryFilename replaces the contents of the string pointed to in their filenames.

The format of the TemporaryFilename method is:

void TemporaryFilename ( char *filename );

A description of each parameter follows.

filename:

Specifies a pointer to an array of characters. The unique file name is returned in this array.


TranslateText

Method TranslateText replaces any embedded formatting characters with the appropriate image attribute and returns the translated text.

The format of the TranslateText method is:

char *TranslateText ( const ImageInfo *image_info, const Image *image, const char *formatted_text );

A description of each parameter follows:

translated_text:

Method TranslateText returns the translated text string.

image_info:

The address of a structure of type ImageInfo.

image:

The address of a structure of type Image.

formatted_text:

The address of a character string containing the embedded formatting characters.