Blame IlmImf/ImfMisc.cpp

Packit 0d464f
///////////////////////////////////////////////////////////////////////////
Packit 0d464f
//
Packit 0d464f
// Copyright (c) 2004, Industrial Light & Magic, a division of Lucas
Packit 0d464f
// Digital Ltd. LLC
Packit 0d464f
// 
Packit 0d464f
// All rights reserved.
Packit 0d464f
// 
Packit 0d464f
// Redistribution and use in source and binary forms, with or without
Packit 0d464f
// modification, are permitted provided that the following conditions are
Packit 0d464f
// met:
Packit 0d464f
// *       Redistributions of source code must retain the above copyright
Packit 0d464f
// notice, this list of conditions and the following disclaimer.
Packit 0d464f
// *       Redistributions in binary form must reproduce the above
Packit 0d464f
// copyright notice, this list of conditions and the following disclaimer
Packit 0d464f
// in the documentation and/or other materials provided with the
Packit 0d464f
// distribution.
Packit 0d464f
// *       Neither the name of Industrial Light & Magic nor the names of
Packit 0d464f
// its contributors may be used to endorse or promote products derived
Packit 0d464f
// from this software without specific prior written permission. 
Packit 0d464f
// 
Packit 0d464f
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 0d464f
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 0d464f
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 0d464f
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
Packit 0d464f
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
Packit 0d464f
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
Packit 0d464f
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
Packit 0d464f
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
Packit 0d464f
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Packit 0d464f
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Packit 0d464f
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 0d464f
//
Packit 0d464f
///////////////////////////////////////////////////////////////////////////
Packit 0d464f
Packit 0d464f
Packit 0d464f
Packit 0d464f
//-----------------------------------------------------------------------------
Packit 0d464f
//
Packit 0d464f
//	Miscellaneous helper functions for OpenEXR image file I/O
Packit 0d464f
//
Packit 0d464f
//-----------------------------------------------------------------------------
Packit 0d464f
Packit 0d464f
#include <ImfMisc.h>
Packit 0d464f
#include <ImfHeader.h>
Packit 0d464f
#include <ImfAttribute.h>
Packit 0d464f
#include <ImfCompressor.h>
Packit 0d464f
#include <ImfChannelList.h>
Packit 0d464f
#include <ImfXdr.h>
Packit 0d464f
#include <ImathFun.h>
Packit 0d464f
#include <Iex.h>
Packit 0d464f
#include <ImfStdIO.h>
Packit 0d464f
#include <ImfConvert.h>
Packit 0d464f
#include <ImfPartType.h>
Packit 0d464f
#include <ImfTileDescription.h>
Packit 0d464f
#include "ImfNamespace.h"
Packit 0d464f
Packit 0d464f
OPENEXR_IMF_INTERNAL_NAMESPACE_SOURCE_ENTER
Packit 0d464f
Packit 0d464f
using IMATH_NAMESPACE::Box2i;
Packit 0d464f
using IMATH_NAMESPACE::divp;
Packit 0d464f
using IMATH_NAMESPACE::modp;
Packit 0d464f
using std::vector;
Packit 0d464f
Packit 0d464f
int
Packit 0d464f
pixelTypeSize (PixelType type)
Packit 0d464f
{
Packit 0d464f
    int size;
Packit 0d464f
Packit 0d464f
    switch (type)
Packit 0d464f
    {
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
	
Packit 0d464f
	size = Xdr::size <unsigned int> ();
Packit 0d464f
	break;
Packit 0d464f
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
	size = Xdr::size <half> ();
Packit 0d464f
	break;
Packit 0d464f
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
	size = Xdr::size <float> ();
Packit 0d464f
	break;
Packit 0d464f
Packit 0d464f
      default:
Packit 0d464f
Packit 0d464f
	throw IEX_NAMESPACE::ArgExc ("Unknown pixel type.");
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    return size;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
int
Packit 0d464f
numSamples (int s, int a, int b)
Packit 0d464f
{
Packit 0d464f
    int a1 = divp (a, s);
Packit 0d464f
    int b1 = divp (b, s);
Packit 0d464f
    return  b1 - a1 + ((a1 * s < a)? 0: 1);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
size_t
Packit 0d464f
bytesPerLineTable (const Header &header,
Packit 0d464f
		   vector<size_t> &bytesPerLine)
Packit 0d464f
{
Packit 0d464f
    const Box2i &dataWindow = header.dataWindow();
Packit 0d464f
    const ChannelList &channels = header.channels();
Packit 0d464f
Packit 0d464f
    bytesPerLine.resize (dataWindow.max.y - dataWindow.min.y + 1);
Packit 0d464f
Packit 0d464f
    for (ChannelList::ConstIterator c = channels.begin();
Packit 0d464f
	 c != channels.end();
Packit 0d464f
	 ++c)
Packit 0d464f
    {
Packit 0d464f
	int nBytes = pixelTypeSize (c.channel().type) *
Packit 0d464f
		     (dataWindow.max.x - dataWindow.min.x + 1) /
Packit 0d464f
		     c.channel().xSampling;
Packit 0d464f
Packit 0d464f
	for (int y = dataWindow.min.y, i = 0; y <= dataWindow.max.y; ++y, ++i)
Packit 0d464f
	    if (modp (y, c.channel().ySampling) == 0)
Packit 0d464f
		bytesPerLine[i] += nBytes;
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    size_t maxBytesPerLine = 0;
Packit 0d464f
Packit 0d464f
    for (int y = dataWindow.min.y, i = 0; y <= dataWindow.max.y; ++y, ++i)
Packit 0d464f
	if (maxBytesPerLine < bytesPerLine[i])
Packit 0d464f
	    maxBytesPerLine = bytesPerLine[i];
Packit 0d464f
Packit 0d464f
    return maxBytesPerLine;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
const int&
Packit 0d464f
sampleCount(const char* base, int xStride, int yStride, int x, int y)
Packit 0d464f
{
Packit 0d464f
    const char* ptr = base + y * yStride + x * xStride;
Packit 0d464f
    int* intPtr = (int*) ptr;
Packit 0d464f
Packit 0d464f
    return *intPtr;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
int&
Packit 0d464f
sampleCount(char* base, int xStride, int yStride, int x, int y)
Packit 0d464f
{
Packit 0d464f
    char* ptr = base + y * yStride + x * xStride;
Packit 0d464f
    int* intPtr = (int*) ptr;
Packit 0d464f
    
Packit 0d464f
    return *intPtr;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
size_t
Packit 0d464f
bytesPerDeepLineTable (const Header &header,
Packit 0d464f
                       int minY, int maxY,
Packit 0d464f
                       const char* base,
Packit 0d464f
                       int xStride,
Packit 0d464f
                       int yStride,
Packit 0d464f
                       vector<size_t> &bytesPerLine)
Packit 0d464f
{
Packit 0d464f
    const Box2i &dataWindow = header.dataWindow();
Packit 0d464f
    const ChannelList &channels = header.channels();
Packit 0d464f
Packit 0d464f
    for (ChannelList::ConstIterator c = channels.begin();
Packit 0d464f
         c != channels.end();
Packit 0d464f
         ++c)
Packit 0d464f
    {
Packit 0d464f
        for (int y = minY; y <= maxY; ++y)
Packit 0d464f
            if (modp (y, c.channel().ySampling) == 0)
Packit 0d464f
            {
Packit 0d464f
                int nBytes = 0;
Packit 0d464f
                for (int x = dataWindow.min.x; x <= dataWindow.max.x; x++)
Packit 0d464f
                {
Packit 0d464f
                    if (modp (x, c.channel().xSampling) == 0)
Packit 0d464f
                        nBytes += pixelTypeSize (c.channel().type) *
Packit 0d464f
                                  sampleCount(base, xStride, yStride, x, y);
Packit 0d464f
                }
Packit 0d464f
                bytesPerLine[y - dataWindow.min.y] += nBytes;
Packit 0d464f
            }
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    size_t maxBytesPerLine = 0;
Packit 0d464f
Packit 0d464f
    for (int y = minY; y <= maxY; ++y)
Packit 0d464f
        if (maxBytesPerLine < bytesPerLine[y - dataWindow.min.y])
Packit 0d464f
            maxBytesPerLine = bytesPerLine[y - dataWindow.min.y];
Packit 0d464f
Packit 0d464f
    return maxBytesPerLine;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
size_t
Packit 0d464f
bytesPerDeepLineTable (const Header &header,
Packit 0d464f
                       char* base,
Packit 0d464f
                       int xStride,
Packit 0d464f
                       int yStride,
Packit 0d464f
                       vector<size_t> &bytesPerLine)
Packit 0d464f
{
Packit 0d464f
    return bytesPerDeepLineTable(header,
Packit 0d464f
                                 header.dataWindow().min.y,
Packit 0d464f
                                 header.dataWindow().max.y,
Packit 0d464f
                                 base,
Packit 0d464f
                                 xStride,
Packit 0d464f
                                 yStride,
Packit 0d464f
                                 bytesPerLine);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
offsetInLineBufferTable (const vector<size_t> &bytesPerLine,
Packit 0d464f
                         int scanline1, int scanline2,
Packit 0d464f
                         int linesInLineBuffer,
Packit 0d464f
                         vector<size_t> &offsetInLineBuffer)
Packit 0d464f
{
Packit 0d464f
    offsetInLineBuffer.resize (bytesPerLine.size());
Packit 0d464f
Packit 0d464f
    size_t offset = 0;
Packit 0d464f
Packit 0d464f
    for (int i = scanline1; i <= scanline2; ++i)
Packit 0d464f
    {
Packit 0d464f
        if (i % linesInLineBuffer == 0)
Packit 0d464f
            offset = 0;
Packit 0d464f
Packit 0d464f
        offsetInLineBuffer[i] = offset;
Packit 0d464f
        offset += bytesPerLine[i];
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
offsetInLineBufferTable (const vector<size_t> &bytesPerLine,
Packit 0d464f
			 int linesInLineBuffer,
Packit 0d464f
			 vector<size_t> &offsetInLineBuffer)
Packit 0d464f
{
Packit 0d464f
    offsetInLineBufferTable (bytesPerLine,
Packit 0d464f
                             0, bytesPerLine.size() - 1,
Packit 0d464f
                             linesInLineBuffer,
Packit 0d464f
                             offsetInLineBuffer);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
int
Packit 0d464f
lineBufferMinY (int y, int minY, int linesInLineBuffer)
Packit 0d464f
{
Packit 0d464f
    return ((y - minY) / linesInLineBuffer) * linesInLineBuffer + minY;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
int
Packit 0d464f
lineBufferMaxY (int y, int minY, int linesInLineBuffer)
Packit 0d464f
{
Packit 0d464f
    return lineBufferMinY (y, minY, linesInLineBuffer) + linesInLineBuffer - 1;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
Compressor::Format
Packit 0d464f
defaultFormat (Compressor * compressor)
Packit 0d464f
{
Packit 0d464f
    return compressor? compressor->format(): Compressor::XDR;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
int
Packit 0d464f
numLinesInBuffer (Compressor * compressor)
Packit 0d464f
{
Packit 0d464f
    return compressor? compressor->numScanLines(): 1;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
copyIntoFrameBuffer (const char *& readPtr,
Packit 0d464f
		     char * writePtr,
Packit 0d464f
		     char * endPtr,
Packit 0d464f
                     size_t xStride,
Packit 0d464f
		     bool fill,
Packit 0d464f
		     double fillValue,
Packit 0d464f
                     Compressor::Format format,
Packit 0d464f
                     PixelType typeInFrameBuffer,
Packit 0d464f
                     PixelType typeInFile)
Packit 0d464f
{
Packit 0d464f
    //
Packit 0d464f
    // Copy a horizontal row of pixels from an input
Packit 0d464f
    // file's line or tile buffer to a frame buffer.
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    if (fill)
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The file contains no data for this channel.
Packit 0d464f
        // Store a default value in the frame buffer.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (typeInFrameBuffer)
Packit 0d464f
        {
Packit 0d464f
	  case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
            
Packit 0d464f
            {
Packit 0d464f
                unsigned int fillVal = (unsigned int) (fillValue);
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    *(unsigned int *) writePtr = fillVal;
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            {
Packit 0d464f
                half fillVal = half (fillValue);
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    *(half *) writePtr = fillVal;
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            {
Packit 0d464f
                float fillVal = float (fillValue);
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    *(float *) writePtr = fillVal;
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
    else if (format == Compressor::XDR)
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The the line or tile buffer is in XDR format.
Packit 0d464f
        //
Packit 0d464f
        // Convert the pixels from the file's machine-
Packit 0d464f
        // independent representation, and store the
Packit 0d464f
        // results in the frame buffer.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (typeInFrameBuffer)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
    
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, *(unsigned int *) writePtr);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    half h;
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, h);
Packit 0d464f
                    *(unsigned int *) writePtr = halfToUint (h);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    float f;
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, f);
Packit 0d464f
                    *(unsigned int *)writePtr = floatToUint (f);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
                
Packit 0d464f
              default:                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    unsigned int ui;
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, ui);
Packit 0d464f
                    *(half *) writePtr = uintToHalf (ui);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
                
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, *(half *) writePtr);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    float f;
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, f);
Packit 0d464f
                    *(half *) writePtr = floatToHalf (f);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    unsigned int ui;
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, ui);
Packit 0d464f
                    *(float *) writePtr = float (ui);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    half h;
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, h);
Packit 0d464f
                    *(float *) writePtr = float (h);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    Xdr::read <CharPtrIO> (readPtr, *(float *) writePtr);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
    else
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The the line or tile buffer is in NATIVE format.
Packit 0d464f
        // Copy the results into the frame buffer.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (typeInFrameBuffer)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
    
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    for (size_t i = 0; i < sizeof (unsigned int); ++i)
Packit 0d464f
                        writePtr[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                    readPtr += sizeof (unsigned int);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    half h = *(half *) readPtr;
Packit 0d464f
                    *(unsigned int *) writePtr = halfToUint (h);
Packit 0d464f
                    readPtr += sizeof (half);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    float f;
Packit 0d464f
Packit 0d464f
                    for (size_t i = 0; i < sizeof (float); ++i)
Packit 0d464f
                        ((char *)&f)[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                    *(unsigned int *)writePtr = floatToUint (f);
Packit 0d464f
                    readPtr += sizeof (float);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
                
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    unsigned int ui;
Packit 0d464f
Packit 0d464f
                    for (size_t i = 0; i < sizeof (unsigned int); ++i)
Packit 0d464f
                        ((char *)&ui)[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                    *(half *) writePtr = uintToHalf (ui);
Packit 0d464f
                    readPtr += sizeof (unsigned int);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                // If we're tightly packed, just memcpy
Packit 0d464f
                if (xStride == sizeof(half)) {
Packit 0d464f
                    int numBytes = endPtr-writePtr+sizeof(half);
Packit 0d464f
                    memcpy(writePtr, readPtr, numBytes);
Packit 0d464f
                    readPtr  += numBytes;
Packit 0d464f
                    writePtr += numBytes;                    
Packit 0d464f
                } else {
Packit 0d464f
                    while (writePtr <= endPtr)
Packit 0d464f
                    {
Packit 0d464f
                        *(half *) writePtr = *(half *)readPtr;
Packit 0d464f
                        readPtr += sizeof (half);
Packit 0d464f
                        writePtr += xStride;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    float f;
Packit 0d464f
Packit 0d464f
                    for (size_t i = 0; i < sizeof (float); ++i)
Packit 0d464f
                        ((char *)&f)[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                    *(half *) writePtr = floatToHalf (f);
Packit 0d464f
                    readPtr += sizeof (float);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    unsigned int ui;
Packit 0d464f
Packit 0d464f
                    for (size_t i = 0; i < sizeof (unsigned int); ++i)
Packit 0d464f
                        ((char *)&ui)[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                    *(float *) writePtr = float (ui);
Packit 0d464f
                    readPtr += sizeof (unsigned int);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    half h = *(half *) readPtr;
Packit 0d464f
                    *(float *) writePtr = float (h);
Packit 0d464f
                    readPtr += sizeof (half);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                while (writePtr <= endPtr)
Packit 0d464f
                {
Packit 0d464f
                    for (size_t i = 0; i < sizeof (float); ++i)
Packit 0d464f
                        writePtr[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                    readPtr += sizeof (float);
Packit 0d464f
                    writePtr += xStride;
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
copyIntoDeepFrameBuffer (const char *& readPtr,
Packit 0d464f
                         char * base,
Packit 0d464f
                         const char* sampleCountBase,
Packit 0d464f
                         ptrdiff_t sampleCountXStride,
Packit 0d464f
                         ptrdiff_t sampleCountYStride,
Packit 0d464f
                         int y, int minX, int maxX,
Packit 0d464f
                         int xOffsetForSampleCount,
Packit 0d464f
                         int yOffsetForSampleCount,
Packit 0d464f
                         int xOffsetForData,
Packit 0d464f
                         int yOffsetForData,
Packit 0d464f
                         ptrdiff_t sampleStride,
Packit 0d464f
                         ptrdiff_t xPointerStride,
Packit 0d464f
                         ptrdiff_t yPointerStride,
Packit 0d464f
                         bool fill,
Packit 0d464f
                         double fillValue,
Packit 0d464f
                         Compressor::Format format,
Packit 0d464f
                         PixelType typeInFrameBuffer,
Packit 0d464f
                         PixelType typeInFile)
Packit 0d464f
{
Packit 0d464f
    //
Packit 0d464f
    // Copy a horizontal row of pixels from an input
Packit 0d464f
    // file's line or tile buffer to a frame buffer.
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    if (fill)
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The file contains no data for this channel.
Packit 0d464f
        // Store a default value in the frame buffer.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (typeInFrameBuffer)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            {
Packit 0d464f
                unsigned int fillVal = (unsigned int) (fillValue);
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                        int count = sampleCount(sampleCountBase,
Packit 0d464f
                                                sampleCountXStride,
Packit 0d464f
                                                sampleCountYStride,
Packit 0d464f
                                                x - xOffsetForSampleCount,
Packit 0d464f
                                                y - yOffsetForSampleCount);
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            *(unsigned int *) writePtr = fillVal;
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            {
Packit 0d464f
                half fillVal = half (fillValue);
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {                            
Packit 0d464f
                        int count = sampleCount(sampleCountBase,
Packit 0d464f
                                                sampleCountXStride,
Packit 0d464f
                                                sampleCountYStride,
Packit 0d464f
                                                x - xOffsetForSampleCount,
Packit 0d464f
                                                y - yOffsetForSampleCount);
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            *(half *) writePtr = fillVal;
Packit 0d464f
                           writePtr += sampleStride;
Packit 0d464f
                       }
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            {
Packit 0d464f
                float fillVal = float (fillValue);
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                        int count = sampleCount(sampleCountBase,
Packit 0d464f
                                                sampleCountXStride,
Packit 0d464f
                                                sampleCountYStride,
Packit 0d464f
                                                x - xOffsetForSampleCount,
Packit 0d464f
                                                y - yOffsetForSampleCount);
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            *(float *) writePtr = fillVal;
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
    else if (format == Compressor::XDR)
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The the line or tile buffer is in XDR format.
Packit 0d464f
        //
Packit 0d464f
        // Convert the pixels from the file's machine-
Packit 0d464f
        // independent representation, and store the
Packit 0d464f
        // results in the frame buffer.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (typeInFrameBuffer)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                   
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, *(unsigned int *) writePtr);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }else{
Packit 0d464f
                        Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<unsigned int>());
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            half h;
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, h);
Packit 0d464f
                           *(unsigned int *) writePtr = halfToUint (h);
Packit 0d464f
                           writePtr += sampleStride;
Packit 0d464f
                       }
Packit 0d464f
                    }else{
Packit 0d464f
                       Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<half>());
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                                                                        
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            float f;
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, f);
Packit 0d464f
                            *(unsigned int *)writePtr = floatToUint (f);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        } 
Packit 0d464f
                     }else{
Packit 0d464f
                       Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<float>());
Packit 0d464f
                     }
Packit 0d464f
                
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            unsigned int ui;
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, ui);
Packit 0d464f
                            *(half *) writePtr = uintToHalf (ui);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }else{
Packit 0d464f
                        Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<unsigned int>());
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                    
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, *(half *) writePtr);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }else{
Packit 0d464f
                        Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<half>());
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **) (base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            float f;
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, f);
Packit 0d464f
                            *(half *) writePtr = floatToHalf (f);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }else{
Packit 0d464f
                        Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<float>());
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            unsigned int ui;
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, ui);
Packit 0d464f
                            *(float *) writePtr = float (ui);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }else{
Packit 0d464f
                        Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<unsigned int>());
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            half h;
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, h);
Packit 0d464f
                            *(float *) writePtr = float (h);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    
Packit 0d464f
                   }else{
Packit 0d464f
                      Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<half>());
Packit 0d464f
                   }               
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                    
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            Xdr::read <CharPtrIO> (readPtr, *(float *) writePtr);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    } else{
Packit 0d464f
                        Xdr::skip <CharPtrIO> (readPtr,count*Xdr::size<float>());
Packit 0d464f
                    }      
Packit 0d464f
                    
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
    else
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The the line or tile buffer is in NATIVE format.
Packit 0d464f
        // Copy the results into the frame buffer.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (typeInFrameBuffer)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                         for (int i = 0; i < count; i++)
Packit 0d464f
                         {
Packit 0d464f
                             for (size_t i = 0; i < sizeof (unsigned int); ++i)
Packit 0d464f
                                 writePtr[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                             readPtr += sizeof (unsigned int);
Packit 0d464f
                             writePtr += sampleStride;
Packit 0d464f
                         }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(unsigned int)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            half h = *(half *) readPtr;
Packit 0d464f
                            *(unsigned int *) writePtr = halfToUint (h);
Packit 0d464f
                            readPtr += sizeof (half);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(half)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                    
Packit 0d464f
                        for (int i = 0; i < count; i++)
Packit 0d464f
                        {
Packit 0d464f
                            float f;
Packit 0d464f
Packit 0d464f
                            for (size_t i = 0; i < sizeof (float); ++i)
Packit 0d464f
                                ((char *)&f)[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                            *(unsigned int *)writePtr = floatToUint (f);
Packit 0d464f
                            readPtr += sizeof (float);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                        }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(float)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                         for (int i = 0; i < count; i++)
Packit 0d464f
                         {
Packit 0d464f
                             unsigned int ui;
Packit 0d464f
 
Packit 0d464f
                             for (size_t i = 0; i < sizeof (unsigned int); ++i)
Packit 0d464f
                                 ((char *)&ui)[i] = readPtr[i];
Packit 0d464f
  
Packit 0d464f
                             *(half *) writePtr = uintToHalf (ui);
Packit 0d464f
                             readPtr += sizeof (unsigned int);
Packit 0d464f
                             writePtr += sampleStride;
Packit 0d464f
                         }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(unsigned int)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                         for (int i = 0; i < count; i++)
Packit 0d464f
                         {
Packit 0d464f
                             *(half *) writePtr = *(half *)readPtr;
Packit 0d464f
                             readPtr += sizeof (half);
Packit 0d464f
                             writePtr += sampleStride;
Packit 0d464f
                         }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(half)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                         for (int i = 0; i < count; i++)
Packit 0d464f
                         {
Packit 0d464f
                            float f;
Packit 0d464f
Packit 0d464f
                             for (size_t i = 0; i < sizeof (float); ++i)
Packit 0d464f
                                 ((char *)&f)[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                            *(half *) writePtr = floatToHalf (f);
Packit 0d464f
                            readPtr += sizeof (float);
Packit 0d464f
                            writePtr += sampleStride;
Packit 0d464f
                         }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(float)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            switch (typeInFile)
Packit 0d464f
            {
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                         for (int i = 0; i < count; i++)
Packit 0d464f
                         {
Packit 0d464f
                              unsigned int ui;
Packit 0d464f
 
Packit 0d464f
                              for (size_t i = 0; i < sizeof (unsigned int); ++i)
Packit 0d464f
                                  ((char *)&ui)[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                              *(float *) writePtr = float (ui);
Packit 0d464f
                              readPtr += sizeof (unsigned int);
Packit 0d464f
                              writePtr += sampleStride;
Packit 0d464f
                         }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(unsigned int)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                         for (int i = 0; i < count; i++)
Packit 0d464f
                         {
Packit 0d464f
                             half h = *(half *) readPtr;
Packit 0d464f
                             *(float *) writePtr = float (h);
Packit 0d464f
                             readPtr += sizeof (half);
Packit 0d464f
                             writePtr += sampleStride;
Packit 0d464f
                         }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(half)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
Packit 0d464f
              case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
                for (int x = minX; x <= maxX; x++)
Packit 0d464f
                {
Packit 0d464f
                    char* writePtr = *(char **)(base+(y-yOffsetForData)*yPointerStride + (x-xOffsetForData)*xPointerStride);
Packit 0d464f
                    
Packit 0d464f
                    int count = sampleCount(sampleCountBase,
Packit 0d464f
                                            sampleCountXStride,
Packit 0d464f
                                            sampleCountYStride,
Packit 0d464f
                                            x - xOffsetForSampleCount,
Packit 0d464f
                                            y - yOffsetForSampleCount);
Packit 0d464f
                                            
Packit 0d464f
                    if(writePtr)
Packit 0d464f
                    {
Packit 0d464f
                         for (int i = 0; i < count; i++)
Packit 0d464f
                         {
Packit 0d464f
                              for (size_t i = 0; i < sizeof (float); ++i)
Packit 0d464f
                                  writePtr[i] = readPtr[i];
Packit 0d464f
Packit 0d464f
                             readPtr += sizeof (float);
Packit 0d464f
                             writePtr += sampleStride;
Packit 0d464f
                         }
Packit 0d464f
                    }else{
Packit 0d464f
                        readPtr+=sizeof(float)*count;
Packit 0d464f
                    }
Packit 0d464f
                }
Packit 0d464f
                break;
Packit 0d464f
              default:
Packit 0d464f
                  
Packit 0d464f
                  throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
skipChannel (const char *& readPtr,
Packit 0d464f
             PixelType typeInFile,
Packit 0d464f
	     size_t xSize)
Packit 0d464f
{
Packit 0d464f
    switch (typeInFile)
Packit 0d464f
    {
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
        
Packit 0d464f
        Xdr::skip <CharPtrIO> (readPtr, Xdr::size <unsigned int> () * xSize);
Packit 0d464f
        break;
Packit 0d464f
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
        Xdr::skip <CharPtrIO> (readPtr, Xdr::size <half> () * xSize);
Packit 0d464f
        break;
Packit 0d464f
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
        Xdr::skip <CharPtrIO> (readPtr, Xdr::size <float> () * xSize);
Packit 0d464f
        break;
Packit 0d464f
Packit 0d464f
      default:
Packit 0d464f
Packit 0d464f
        throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
convertInPlace (char *& writePtr,
Packit 0d464f
                const char *& readPtr,
Packit 0d464f
		PixelType type,
Packit 0d464f
                size_t numPixels)
Packit 0d464f
{
Packit 0d464f
    switch (type)
Packit 0d464f
    {
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
    
Packit 0d464f
        for (size_t j = 0; j < numPixels; ++j)
Packit 0d464f
        {
Packit 0d464f
            Xdr::write <CharPtrIO> (writePtr, *(const unsigned int *) readPtr);
Packit 0d464f
            readPtr += sizeof(unsigned int);
Packit 0d464f
        }
Packit 0d464f
        break;
Packit 0d464f
    
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
    
Packit 0d464f
        for (size_t j = 0; j < numPixels; ++j)
Packit 0d464f
        {               
Packit 0d464f
            Xdr::write <CharPtrIO> (writePtr, *(const half *) readPtr);
Packit 0d464f
            readPtr += sizeof(half);
Packit 0d464f
        }
Packit 0d464f
        break;
Packit 0d464f
    
Packit 0d464f
      case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
    
Packit 0d464f
        for (size_t j = 0; j < numPixels; ++j)
Packit 0d464f
        {
Packit 0d464f
            Xdr::write <CharPtrIO> (writePtr, *(const float *) readPtr);
Packit 0d464f
            readPtr += sizeof(float);
Packit 0d464f
        }
Packit 0d464f
        break;
Packit 0d464f
    
Packit 0d464f
      default:
Packit 0d464f
    
Packit 0d464f
        throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
copyFromFrameBuffer (char *& writePtr,
Packit 0d464f
		     const char *& readPtr,
Packit 0d464f
                     const char * endPtr,
Packit 0d464f
		     size_t xStride,
Packit 0d464f
                     Compressor::Format format,
Packit 0d464f
		     PixelType type)
Packit 0d464f
{
Packit 0d464f
    //
Packit 0d464f
    // Copy a horizontal row of pixels from a frame
Packit 0d464f
    // buffer to an output file's line or tile buffer.
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    if (format == Compressor::XDR)
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The the line or tile buffer is in XDR format.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (type)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            while (readPtr <= endPtr)
Packit 0d464f
            {
Packit 0d464f
                Xdr::write <CharPtrIO> (writePtr,
Packit 0d464f
                                        *(const unsigned int *) readPtr);
Packit 0d464f
                readPtr += xStride;
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            while (readPtr <= endPtr)
Packit 0d464f
            {
Packit 0d464f
                Xdr::write <CharPtrIO> (writePtr, *(const half *) readPtr);
Packit 0d464f
                readPtr += xStride;
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            while (readPtr <= endPtr)
Packit 0d464f
            {
Packit 0d464f
                Xdr::write <CharPtrIO> (writePtr, *(const float *) readPtr);
Packit 0d464f
                readPtr += xStride;
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
    else
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The the line or tile buffer is in NATIVE format.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (type)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            while (readPtr <= endPtr)
Packit 0d464f
            {
Packit 0d464f
                for (size_t i = 0; i < sizeof (unsigned int); ++i)
Packit 0d464f
                    *writePtr++ = readPtr[i];
Packit 0d464f
Packit 0d464f
                readPtr += xStride;
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            while (readPtr <= endPtr)
Packit 0d464f
            {
Packit 0d464f
                *(half *) writePtr = *(const half *) readPtr;
Packit 0d464f
                writePtr += sizeof (half);
Packit 0d464f
                readPtr += xStride;
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            while (readPtr <= endPtr)
Packit 0d464f
            {
Packit 0d464f
                for (size_t i = 0; i < sizeof (float); ++i)
Packit 0d464f
                    *writePtr++ = readPtr[i];
Packit 0d464f
Packit 0d464f
                readPtr += xStride;
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
            
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
copyFromDeepFrameBuffer (char *& writePtr,
Packit 0d464f
                         const char * base,
Packit 0d464f
                         char* sampleCountBase,
Packit 0d464f
                         ptrdiff_t sampleCountXStride,
Packit 0d464f
                         ptrdiff_t sampleCountYStride,
Packit 0d464f
                         int y, int xMin, int xMax,
Packit 0d464f
                         int xOffsetForSampleCount,
Packit 0d464f
                         int yOffsetForSampleCount,
Packit 0d464f
                         int xOffsetForData,
Packit 0d464f
                         int yOffsetForData,
Packit 0d464f
                         ptrdiff_t sampleStride,
Packit 0d464f
                         ptrdiff_t dataXStride,
Packit 0d464f
                         ptrdiff_t dataYStride,
Packit 0d464f
                         Compressor::Format format,
Packit 0d464f
                         PixelType type)
Packit 0d464f
{
Packit 0d464f
    //
Packit 0d464f
    // Copy a horizontal row of pixels from a frame
Packit 0d464f
    // buffer to an output file's line or tile buffer.
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    if (format == Compressor::XDR)
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The the line or tile buffer is in XDR format.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (type)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            for (int x = xMin; x <= xMax; x++)
Packit 0d464f
            {
Packit 0d464f
                unsigned int count =
Packit 0d464f
                        sampleCount(sampleCountBase,
Packit 0d464f
                                   sampleCountXStride,
Packit 0d464f
                                   sampleCountYStride,
Packit 0d464f
                                   x - xOffsetForSampleCount,
Packit 0d464f
                                   y - yOffsetForSampleCount);
Packit 0d464f
                const char* ptr = base + (y-yOffsetForData) * dataYStride + (x-xOffsetForData) * dataXStride;
Packit 0d464f
                const char* readPtr = ((const char**) ptr)[0];
Packit 0d464f
                for (unsigned int i = 0; i < count; i++)
Packit 0d464f
                {
Packit 0d464f
                    Xdr::write <CharPtrIO> (writePtr,
Packit 0d464f
                                            *(const unsigned int *) readPtr);
Packit 0d464f
                    readPtr += sampleStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            for (int x = xMin; x <= xMax; x++)
Packit 0d464f
            {
Packit 0d464f
                unsigned int count =
Packit 0d464f
                        sampleCount(sampleCountBase,
Packit 0d464f
                                   sampleCountXStride,
Packit 0d464f
                                   sampleCountYStride,
Packit 0d464f
                                   x - xOffsetForSampleCount,
Packit 0d464f
                                   y - yOffsetForSampleCount);
Packit 0d464f
                const char* ptr = base + (y-yOffsetForData) * dataYStride + (x-xOffsetForData) * dataXStride;
Packit 0d464f
                const char* readPtr = ((const char**) ptr)[0];
Packit 0d464f
                for (unsigned int i = 0; i < count; i++)
Packit 0d464f
                {
Packit 0d464f
                    Xdr::write <CharPtrIO> (writePtr, *(const half *) readPtr);
Packit 0d464f
                    readPtr += sampleStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            for (int x = xMin; x <= xMax; x++)
Packit 0d464f
            {
Packit 0d464f
                unsigned int count =
Packit 0d464f
                        sampleCount(sampleCountBase,
Packit 0d464f
                                   sampleCountXStride,
Packit 0d464f
                                   sampleCountYStride,
Packit 0d464f
                                   x - xOffsetForSampleCount,
Packit 0d464f
                                   y - yOffsetForSampleCount);
Packit 0d464f
                const char* ptr = base + (y-yOffsetForData) * dataYStride + (x-xOffsetForData) * dataXStride;                                   
Packit 0d464f
                                   
Packit 0d464f
                const char* readPtr = ((const char**) ptr)[0];
Packit 0d464f
                for (unsigned int i = 0; i < count; i++)
Packit 0d464f
                {
Packit 0d464f
                    Xdr::write <CharPtrIO> (writePtr, *(const float *) readPtr);
Packit 0d464f
                    readPtr += sampleStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
    else
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // The the line or tile buffer is in NATIVE format.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (type)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            for (int x = xMin; x <= xMax; x++)
Packit 0d464f
            {
Packit 0d464f
                unsigned int count =
Packit 0d464f
                        sampleCount(sampleCountBase,
Packit 0d464f
                                   sampleCountXStride,
Packit 0d464f
                                   sampleCountYStride,
Packit 0d464f
                                   x - xOffsetForSampleCount,
Packit 0d464f
                                   y - yOffsetForSampleCount);
Packit 0d464f
                                   
Packit 0d464f
                const char* ptr = base + (y-yOffsetForData) * dataYStride + (x-xOffsetForData) * dataXStride;                                                                      
Packit 0d464f
                const char* readPtr = ((const char**) ptr)[0];
Packit 0d464f
                for (unsigned int i = 0; i < count; i++)
Packit 0d464f
                {
Packit 0d464f
                    for (size_t j = 0; j < sizeof (unsigned int); ++j)
Packit 0d464f
                        *writePtr++ = readPtr[j];
Packit 0d464f
Packit 0d464f
                    readPtr += sampleStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            for (int x = xMin; x <= xMax; x++)
Packit 0d464f
            {
Packit 0d464f
                unsigned int count =
Packit 0d464f
                        sampleCount(sampleCountBase,
Packit 0d464f
                                   sampleCountXStride,
Packit 0d464f
                                   sampleCountYStride,
Packit 0d464f
                                   x - xOffsetForSampleCount,
Packit 0d464f
                                   y - yOffsetForSampleCount);
Packit 0d464f
                const char* ptr = base + (y-yOffsetForData) * dataYStride + (x-xOffsetForData) * dataXStride;                                   
Packit 0d464f
                const char* readPtr = ((const char**) ptr)[0];
Packit 0d464f
                for (unsigned int i = 0; i < count; i++)
Packit 0d464f
                {
Packit 0d464f
                    *(half *) writePtr = *(const half *) readPtr;
Packit 0d464f
                    writePtr += sizeof (half);
Packit 0d464f
                    readPtr += sampleStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            for (int x = xMin; x <= xMax; x++)
Packit 0d464f
            {
Packit 0d464f
                unsigned int count =
Packit 0d464f
                        sampleCount(sampleCountBase,
Packit 0d464f
                                   sampleCountXStride,
Packit 0d464f
                                   sampleCountYStride,
Packit 0d464f
                                   x - xOffsetForSampleCount,
Packit 0d464f
                                   y - yOffsetForSampleCount);
Packit 0d464f
                                   
Packit 0d464f
                const char* ptr = base + (y-yOffsetForData) * dataYStride + (x-xOffsetForData) * dataXStride;                                   
Packit 0d464f
                const char* readPtr = ((const char**) ptr)[0];
Packit 0d464f
                for (unsigned int i = 0; i < count; i++)
Packit 0d464f
                {
Packit 0d464f
                    for (size_t j = 0; j < sizeof (float); ++j)
Packit 0d464f
                        *writePtr++ = readPtr[j];
Packit 0d464f
Packit 0d464f
                    readPtr += sampleStride;
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
fillChannelWithZeroes (char *& writePtr,
Packit 0d464f
		       Compressor::Format format,
Packit 0d464f
		       PixelType type,
Packit 0d464f
		       size_t xSize)
Packit 0d464f
{
Packit 0d464f
    if (format == Compressor::XDR)
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // Fill with data in XDR format.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (type)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            for (size_t j = 0; j < xSize; ++j)
Packit 0d464f
                Xdr::write <CharPtrIO> (writePtr, (unsigned int) 0);
Packit 0d464f
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            for (size_t j = 0; j < xSize; ++j)
Packit 0d464f
                Xdr::write <CharPtrIO> (writePtr, (half) 0);
Packit 0d464f
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            for (size_t j = 0; j < xSize; ++j)
Packit 0d464f
                Xdr::write <CharPtrIO> (writePtr, (float) 0);
Packit 0d464f
Packit 0d464f
            break;
Packit 0d464f
            
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
    else
Packit 0d464f
    {
Packit 0d464f
        //
Packit 0d464f
        // Fill with data in NATIVE format.
Packit 0d464f
        //
Packit 0d464f
Packit 0d464f
        switch (type)
Packit 0d464f
        {
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::UINT:
Packit 0d464f
Packit 0d464f
            for (size_t j = 0; j < xSize; ++j)
Packit 0d464f
            {
Packit 0d464f
                static const unsigned int ui = 0;
Packit 0d464f
Packit 0d464f
                for (size_t i = 0; i < sizeof (ui); ++i)
Packit 0d464f
                    *writePtr++ = ((char *) &ui)[i];
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::HALF:
Packit 0d464f
Packit 0d464f
            for (size_t j = 0; j < xSize; ++j)
Packit 0d464f
            {
Packit 0d464f
                *(half *) writePtr = half (0);
Packit 0d464f
                writePtr += sizeof (half);
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
          case OPENEXR_IMF_INTERNAL_NAMESPACE::FLOAT:
Packit 0d464f
Packit 0d464f
            for (size_t j = 0; j < xSize; ++j)
Packit 0d464f
            {
Packit 0d464f
                static const float f = 0;
Packit 0d464f
Packit 0d464f
                for (size_t i = 0; i < sizeof (f); ++i)
Packit 0d464f
                    *writePtr++ = ((char *) &f)[i];
Packit 0d464f
            }
Packit 0d464f
            break;
Packit 0d464f
            
Packit 0d464f
          default:
Packit 0d464f
Packit 0d464f
            throw IEX_NAMESPACE::ArgExc ("Unknown pixel data type.");
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
bool
Packit 0d464f
usesLongNames (const Header &header)
Packit 0d464f
{
Packit 0d464f
    //
Packit 0d464f
    // If an OpenEXR file contains any attribute names, attribute type names
Packit 0d464f
    // or channel names longer than 31 characters, then the file cannot be
Packit 0d464f
    // read by older versions of the IlmImf library (up to OpenEXR 1.6.1).
Packit 0d464f
    // Before writing the file header, we check if the header contains
Packit 0d464f
    // any names longer than 31 characters; if it does, then we set the
Packit 0d464f
    // LONG_NAMES_FLAG in the file version number.  Older versions of the
Packit 0d464f
    // IlmImf library will refuse to read files that have the LONG_NAMES_FLAG
Packit 0d464f
    // set.  Without the flag, older versions of the library would mis-
Packit 0d464f
    // interpret the file as broken.
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    for (Header::ConstIterator i = header.begin();
Packit 0d464f
         i != header.end();
Packit 0d464f
         ++i)
Packit 0d464f
    {
Packit 0d464f
        if (strlen (i.name()) >= 32 || strlen (i.attribute().typeName()) >= 32)
Packit 0d464f
            return true;
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    const ChannelList &channels = header.channels();
Packit 0d464f
Packit 0d464f
    for (ChannelList::ConstIterator i = channels.begin();
Packit 0d464f
         i != channels.end();
Packit 0d464f
         ++i)
Packit 0d464f
    {
Packit 0d464f
        if (strlen (i.name()) >= 32)
Packit 0d464f
            return true;
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    return false;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
int
Packit 0d464f
getScanlineChunkOffsetTableSize(const Header& header)
Packit 0d464f
{
Packit 0d464f
    const Box2i &dataWindow = header.dataWindow();
Packit 0d464f
Packit 0d464f
    vector<size_t> bytesPerLine;
Packit 0d464f
    size_t maxBytesPerLine = bytesPerLineTable (header,
Packit 0d464f
                                                bytesPerLine);
Packit 0d464f
Packit 0d464f
    Compressor* compressor = newCompressor(header.compression(),
Packit 0d464f
                                           maxBytesPerLine,
Packit 0d464f
                                           header);
Packit 0d464f
Packit 0d464f
    int linesInBuffer = numLinesInBuffer (compressor);
Packit 0d464f
Packit 0d464f
    int lineOffsetSize = (dataWindow.max.y - dataWindow.min.y +
Packit 0d464f
                          linesInBuffer) / linesInBuffer;
Packit 0d464f
Packit 0d464f
    delete compressor;
Packit 0d464f
Packit 0d464f
    return lineOffsetSize;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
//
Packit 0d464f
// Located in ImfTiledMisc.cpp
Packit 0d464f
//
Packit 0d464f
int
Packit 0d464f
getTiledChunkOffsetTableSize(const Header& header);
Packit 0d464f
Packit 0d464f
int
Packit 0d464f
getChunkOffsetTableSize(const Header& header,bool ignore_attribute)
Packit 0d464f
{
Packit 0d464f
    if(!ignore_attribute && header.hasChunkCount())
Packit 0d464f
    {
Packit 0d464f
        return header.chunkCount();
Packit 0d464f
    }
Packit 0d464f
    
Packit 0d464f
    if(header.hasType()  && !isSupportedType(header.type()))
Packit 0d464f
    {
Packit 0d464f
        throw IEX_NAMESPACE::ArgExc ("unsupported header type to "
Packit 0d464f
        "get chunk offset table size");
Packit 0d464f
    }
Packit 0d464f
    if (isTiled(header.type()) == false)
Packit 0d464f
        return getScanlineChunkOffsetTableSize(header);
Packit 0d464f
    else
Packit 0d464f
        return getTiledChunkOffsetTableSize(header);
Packit 0d464f
    
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
OPENEXR_IMF_INTERNAL_NAMESPACE_SOURCE_EXIT