/* PIKA - Photo and Image Kooker Application * a rebranding of The GNU Image Manipulation Program (created with heckimp) * A derived work which may be trivial. However, any changes may be (C)2023 by Aldercone Studio * * Original copyright, applying to most contents (license remains unchanged): * 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 3 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, see . */ #include "config.h" #include #include "core-types.h" #include "pikabrush.h" #include "pikabrush-header.h" #include "pikabrush-save.h" #include "pikatempbuf.h" gboolean pika_brush_save (PikaData *data, GOutputStream *output, GError **error) { PikaBrush *brush = PIKA_BRUSH (data); PikaTempBuf *mask = pika_brush_get_mask (brush); PikaTempBuf *pixmap = pika_brush_get_pixmap (brush); PikaBrushHeader header; const gchar *name; gint width; gint height; name = pika_object_get_name (brush); width = pika_temp_buf_get_width (mask); height = pika_temp_buf_get_height (mask); header.header_size = g_htonl (sizeof (PikaBrushHeader) + strlen (name) + 1); header.version = g_htonl (2); header.width = g_htonl (width); header.height = g_htonl (height); header.bytes = g_htonl (pixmap ? 4 : 1); header.magic_number = g_htonl (PIKA_BRUSH_MAGIC); header.spacing = g_htonl (pika_brush_get_spacing (brush)); if (! g_output_stream_write_all (output, &header, sizeof (header), NULL, NULL, error)) { return FALSE; } if (! g_output_stream_write_all (output, name, strlen (name) + 1, NULL, NULL, error)) { return FALSE; } if (pixmap) { gsize size = width * height * 4; guchar *data = g_malloc (size); guchar *p = pika_temp_buf_get_data (pixmap); guchar *m = pika_temp_buf_get_data (mask); guchar *d = data; gint i; for (i = 0; i < width * height; i++) { *d++ = *p++; *d++ = *p++; *d++ = *p++; *d++ = *m++; } if (! g_output_stream_write_all (output, data, size, NULL, NULL, error)) { g_free (data); return FALSE; } g_free (data); } else { if (! g_output_stream_write_all (output, pika_temp_buf_get_data (mask), pika_temp_buf_get_data_size (mask), NULL, NULL, error)) { return FALSE; } } return TRUE; }