NAME

Imager::Preprocess - simple preprocessor for handling multiple sample sizes

SYNOPSIS

/* in the source: */
#code condition true to work with 8-bit samples
... code using preprocessor types/values ...
#/code

# process and make #line directives
perl -MImager::Preprocess -epreprocess foo.im foo.c

# process and no #line directives
perl -MImager::Preprocess -epreprocess -l foo.im foo.c

DESCRIPTION

This is a simple preprocessor that aims to reduce duplication of source code when implementing an algorithm both for 8-bit samples and double samples in Imager.

Imager's Makefile.PL currently scans the MANIFEST for .im files and adds Makefile files to convert these to .c files.

The beginning of a sample-independent section of code is preceded by:

#code expression

where expression should return true if processing should be done at 8-bits/sample.

You can also use a #code block around a function definition to produce 8-bit and double sample versions of a function. In this case #code has no expression and you will need to use IM_SUFFIX() to produce different function names.

The end of a sample-independent section of code is terminated by:

#/code

#code sections cannot be nested.

#/code without a starting #code is an error.

You can also define extra sample-size dependent macros with #!define:

    #!define common-name eight-bit-name floating-point-name

The following types and values are defined in a #code section:

  • IM_GPIX(im, x, y, &col)

  • IM_GLIN(im, l, r, y, colors)

  • IM_PPIX(im, x, y, &col)

  • IM_PLIN(im, x, y, colors)

  • IM_GSAMP(im, l, r, y, samples, chans, chan_count)

    These correspond to the appropriate image function, eg. IM_GPIX() becomes i_gpix() or i_gpixf() as appropriate.

  • IM_GSAMP_ASSERT(im, l, r, y, samples, chans, chan_count)

  • IM_GSLIN(im, l, r, y, samples, chans, chan_count)

  • IM_GSLIN_ASSERT(im, l, r, y, samples, chans, chan_count)

  • IM_PSLIN(im, l, r, y, samples, chans, chan_count)

  • IM_ADAPT_COLORS(dest_channels, src_channels, colors, count)

    Call i_adapt_colors() or i_adapt_fcolors().

  • IM_FILL_COMBINE(fill) - retrieve the combine function from a fill object.

  • IM_FILL_FILLER(fill) - retrieve the fill_with_* function from a fill object.

  • IM_ABS(sample) - calculate the absolute value of an IM_WORK_T value. (abs(), fabs())

  • IM_SAMPLE_MAX - maximum value for a sample (255, 1.0)

  • IM_SAMPLE_MAX2 - maximum value for a sample, squared

  • IM_SAMPLE_T - type of a sample (i_sample_t, i_fsample_t)

  • IM_LIN_SAMPLE_T - type of a linear sample (i_sample16_t, i_fsample_t)

  • IM_LIN_SAMPLE_MAX - maximum value for a linear sample (65535, 1.0)

  • IM_COLOR - color type (i_color, i_fcolor).

  • IM_WORK_T - working sample type, (int, double).

  • IM_Sf - format string for the sample type, ("%d", "%f").

  • IM_Wf - format string for the work type, ("%d", "%f").

  • IM_SUFFIX(identifier) - adds _8 or _double onto the end of identifier.

  • IM_EIGHT_BIT - this is a macro defined only in 8-bit/sample code.

    #ifdef IM_EIGHT_BIT
     /* 8-bit per sample only code */
    #else
     /* double per sample only code */
    #endif

Other types, functions and values may be added in the future.

AUTHOR

Tony Cook <tonyc@cpan.org>