summaryrefslogtreecommitdiffstats
path: root/filters/chalk/xcf/xcf/xcf-read.cpp
blob: 314daa9009f8823bf8ca062c233127b4e33dbc0c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/* The GIMP -- an image manipulation program
 * Copyright (C) 1995 Spencer Kimball and Peter Mattis
 *
 * 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.
 *
 * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 */

#include "config.h"

#include <stdio.h>

#include <glib-object.h>

#include "libgimpbase/gimpbase.h"

#include "xcf-read.h"

#include "gimp-intl.h"


TQ_UINT32
xcf_read_int32 (FILE    *fp,
		TQ_INT32 *data,
		TQ_INT32     count)
{
  TQ_UINT32 total;

  total = count;
  if (count > 0)
    {
      xcf_read_int8 (fp, (TQ_UINT8 *) data, count * 4);

      while (count--)
        {
          *data = g_ntohl (*data);
          data++;
        }
    }

  return total * 4;
}

TQ_UINT32
xcf_read_float (FILE   *fp,
		float *data,
		TQ_INT32    count)
{
  return xcf_read_int32 (fp, (TQ_INT32 *) ((void *) data), count);
}

TQ_UINT32
xcf_read_int8 (FILE   *fp,
	       TQ_UINT8 *data,
	       TQ_INT32    count)
{
  TQ_UINT32 total;
  TQ_INT32  bytes;

  total = count;
  while (count > 0)
    {
      bytes = fread ((char *) data, sizeof (char), count, fp);
      if (bytes <= 0) /* something bad happened */
        break;
      count -= bytes;
      data += bytes;
    }

  return total;
}

TQ_UINT32
xcf_read_string (FILE   *fp,
		 TQCString **data,
		 TQ_INT32    count)
{
  TQ_INT32 tmp;
  TQ_UINT32   total;
  TQ_INT32    i;

  total = 0;
  for (i = 0; i < count; i++)
    {
      total += xcf_read_int32 (fp, &tmp, 1);
      if (tmp > 0)
        {
          TQCString *str;

          str = g_new (TQCString, tmp);
          total += xcf_read_int8 (fp, (TQ_UINT8*) str, tmp);

          if (str[tmp - 1] != '\0')
            str[tmp - 1] = '\0';

          data[i] = gimp_any_to_utf8 (str, -1,
                                      _("Invalid UTF-8 string in XCF file"));

          g_free (str);
        }
      else
        {
          data[i] = NULL;
        }
    }

  return total;
}