This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/writestreamglue/intern/BLO_writeStreamGlue.c
Kent Mein d0e346d544 updated .c files to include:
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

Just need to finish cpp files now :)

Kent
--
mein@cs.umn.edu
2002-11-25 12:02:15 +00:00

171 lines
5.1 KiB
C

/**
* $Id$
*
* ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version. The Blender
* Foundation also sells licenses for use in proprietary software under
* the Blender License. See http://www.blender.org/BL/ for information
* about this.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
* All rights reserved.
*
* The Original Code is: all of this file.
*
* Contributor(s): none yet.
*
* ***** END GPL/BL DUAL LICENSE BLOCK *****
* connect the data stream processors
*/
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include "zlib.h"
#include "GEN_messaging.h"
#include "BLO_writeStreamGlue.h"
#include "BLO_dumpFromMemory.h"
#include "BLO_writeblenfile.h"
#include "BLO_deflate.h"
#include "BLO_encrypt.h"
#include "BLO_sign.h"
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
/**
* streamGlueWrite does not really stream; it buffers all data it gets
* because it needs everything to create the header, which is in front
* of the data (to make reading easier, which occurs much more often
* than writing and is thus more important to optimize for).
* @param streamControl contains a list of Glue actions. Every
* streamGlueWrite constructor eats up the next first action.
*/
int
writeStreamGlue(
struct streamGlueControlStruct *streamGlueControl,
struct writeStreamGlueStruct **streamGlue,
unsigned char *data,
unsigned int dataIn,
int finishUp)
{
int err = 0;
if (NULL == *streamGlue) {
/* we are called for the first time; play constructor */
(*streamGlue) = malloc(sizeof(struct writeStreamGlueStruct));
if (!(*streamGlue)) {
err = BWS_SETFUNCTION(BWS_WRITESTREAMGLUE) |
BWS_SETGENERR(BWS_MALLOC);
return err;
}
(*streamGlue)->dataProcessorType =
streamGlueControlGetNextAction(streamGlueControl);
(*streamGlue)->streamBufferCount = 0;
(*streamGlue)->streamBuffer = NULL;
}
if (dataIn > 0) {
/* simply buffer it */
(*streamGlue)->streamBuffer = realloc((*streamGlue)->streamBuffer,
dataIn + (*streamGlue)->streamBufferCount);
if (!(*streamGlue)->streamBuffer) {
err = BWS_SETFUNCTION(BWS_WRITESTREAMGLUE) |
BWS_SETGENERR(BWS_MALLOC);
free(*streamGlue);
return err;
}
memcpy((*streamGlue)->streamBuffer + (*streamGlue)->streamBufferCount,
data, dataIn);
(*streamGlue)->streamBufferCount += dataIn;
}
if (finishUp) {
/* all data is in, create header and call data processor */
/* first create the streamGlueHeaderStruct */
struct streamGlueHeaderStruct *streamGlueHeader;
streamGlueHeader = malloc(STREAMGLUEHEADERSIZE);
if (!streamGlueHeader) {
err = BWS_SETFUNCTION(BWS_WRITESTREAMGLUE) |
BWS_SETGENERR(BWS_MALLOC);
free((*streamGlue)->streamBuffer);
free(*streamGlue);
return err;
}
streamGlueHeader->magic = 'A';
streamGlueHeader->totalStreamLength = 0; // set in the actions _end
streamGlueHeader->dataProcessorType =
htonl((*streamGlue)->dataProcessorType);
streamGlueHeader->crc = 0; // set in in the actions _end
#ifndef NDEBUG
fprintf(GEN_errorstream,
"streamGlue: write %d gets %u data + %u streamGlueHeader = %u\n",
(*streamGlue)->dataProcessorType,
(*streamGlue)->streamBufferCount,
STREAMGLUEHEADERSIZE,
(*streamGlue)->streamBufferCount + STREAMGLUEHEADERSIZE);
#endif
/* all data ready, start the right data processor */
switch ((*streamGlue)->dataProcessorType) {
case DUMPFROMMEMORY:
err = BLO_dumpFromMemory((*streamGlue)->streamBuffer,
(*streamGlue)->streamBufferCount,
streamGlueHeader);
break;
case DEFLATE:
err = BLO_deflate((*streamGlue)->streamBuffer,
(*streamGlue)->streamBufferCount,
streamGlueHeader);
break;
case ENCRYPT:
err = BLO_encrypt((*streamGlue)->streamBuffer,
(*streamGlue)->streamBufferCount,
streamGlueHeader);
break;
case SIGN:
err = BLO_sign((*streamGlue)->streamBuffer,
(*streamGlue)->streamBufferCount,
streamGlueHeader);
break;
case WRITEBLENFILE:
err = BLO_writeblenfile((*streamGlue)->streamBuffer,
(*streamGlue)->streamBufferCount,
streamGlueHeader);
break;
default:
#ifndef NDEBUG
fprintf(GEN_errorstream,
"unknown dataProcessorType %d\n",
(*streamGlue)->dataProcessorType);
#endif
err = BWS_SETFUNCTION(BWS_WRITESTREAMGLUE) |
BWS_SETSPECERR(BWS_UNKNOWN);
break;
}
free(streamGlueHeader);
free((*streamGlue)->streamBuffer);
free(*streamGlue);
}
return err;
}