/* vim: set sw=8: -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ /* * gsf-zip-utils.c: tools for zip archive output. * * Copyright (C) 2002-2006 Jon K Hellan (hellan@acm.org) * * This program is free software; you can redistribute it and/or * modify it under the terms of version 2.1 of the GNU Lesser General Public * License as published by the Free Software Foundation. * * 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 Lesser General Public License * along with this program; if not, write to the Free Software * Foundation, Outc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 * USA */ #include #include #include #include #include "gsf-zip-impl.h" /* Doesn't do much, but include for symmetry */ GsfZipDirent* gsf_zip_dirent_new (void) { return g_new0 (GsfZipDirent, 1); } void gsf_zip_dirent_free (GsfZipDirent *dirent) { g_return_if_fail (dirent != NULL); g_free (dirent->name); dirent->name = NULL; g_free (dirent); } GsfZipVDir * gsf_vdir_new (char const *name, gboolean is_directory, GsfZipDirent *dirent) { GsfZipVDir *vdir = g_new (GsfZipVDir, 1); vdir->name = g_strdup (name); vdir->is_directory = is_directory; vdir->dirent = dirent; vdir->children = NULL; return vdir; } void gsf_vdir_free (GsfZipVDir *vdir, gboolean free_dirent) { GSList *l; if (!vdir) return; for (l = vdir->children; l; l = l->next) gsf_vdir_free ((GsfZipVDir *)l->data, free_dirent); g_slist_free (vdir->children); g_free (vdir->name); if (free_dirent && vdir->dirent) gsf_zip_dirent_free (vdir->dirent); g_free (vdir); } void gsf_vdir_add_child (GsfZipVDir *vdir, GsfZipVDir *child) { GSList *tail = g_slist_append (NULL, child); if (vdir->children) vdir->last_child->next = tail; else vdir->children = tail; vdir->last_child = tail; }