style cleanup: brace placement/newlines
[blender.git] / source / blender / imbuf / intern / cineon / logImageLib.h
1 /*
2  *       Common library definitions for Cineon and DPX image files.
3  *
4  *       Copyright 1999,2000,2001 David Hodson <hodsond@acm.org>
5  *
6  *       This program is free software; you can redistribute it and/or modify it
7  *       under the terms of the GNU General Public License as published by the Free
8  *       Software Foundation; either version 2 of the License, or (at your option)
9  *       any later version.
10  *
11  *       This program is distributed in the hope that it will be useful, but
12  *       WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13  *       or FITNESS FOR A PARTICULAR PURPOSE.    See the GNU General Public License
14  *       for more details.
15  *
16  *       You should have received a copy of the GNU General Public License
17  *       along with this program; if not, write to the Free Software
18  *       Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19  *
20  */
21
22 #ifndef __LOGIMAGELIB_H__
23 #define __LOGIMAGELIB_H__
24
25 /** \file blender/imbuf/intern/cineon/logImageLib.h
26  *  \ingroup imbcineon
27  */
28
29 #ifdef __cplusplus
30 extern "C" {
31 #endif
32
33 /*
34  * Image structure. You don't care what this is.
35  */
36
37 typedef struct _Log_Image_File_t_ LogImageFile;
38
39 /*
40  * Magic numbers for normal and byte-swapped Cineon and Dpx files
41  */
42
43 #define CINEON_FILE_MAGIC 0x802A5FD7
44 #define DPX_FILE_MAGIC 0x53445058
45
46 /*
47  * Image 8 bit <-> 10 bit conversion parameters.
48  */
49
50 typedef struct {
51         float gamma;
52         int blackPoint;
53         int whitePoint;
54         int doLogarithm;
55 } LogImageByteConversionParameters;
56
57 /* int functions return 0 for OK */
58
59 void logImageSetVerbose(int);
60
61 LogImageFile* logImageOpenFromMem(unsigned char *buffer, unsigned int size, int cineon);
62 LogImageFile* logImageOpen(const char* filename, int cineon);
63 int logImageGetSize(const LogImageFile* logImage, int* xsize, int* ysize, int* channels);
64 LogImageFile* logImageCreate(const char* filename, int cineon, int xsize, int ysize, int channels);
65
66 /* byte conversion routines for mapping logImage (usually) 10 bit values to 8 bit */
67 /* see Kodak docs for details... */
68
69 int logImageGetByteConversionDefaults(LogImageByteConversionParameters* params);
70 int logImageGetByteConversion(const LogImageFile* logImage, LogImageByteConversionParameters* params);
71 int logImageSetByteConversion(LogImageFile* logImage, const LogImageByteConversionParameters* params);
72
73 /* get/set scanline of converted bytes */
74 int logImageGetRowBytes(LogImageFile* logImage, unsigned short* row, int y);
75 int logImageSetRowBytes(LogImageFile* logImage, const unsigned short* row, int y);
76
77 /* closes file and deletes data */
78 void logImageClose(LogImageFile* logImage);
79
80 /* read file and dump header info */
81 void logImageDump(const char* filename);
82
83 #ifdef __cplusplus
84 }
85 #endif
86
87 #endif /* __LOGIMAGELIB_H__ */