Mercurial > audlegacy
view src/libaudtag/wma/guid.c @ 4887:0ddbd0025174 default tip
added libaudtag. (not used yet.)
author | Yoshiki Yazawa <yaz@honeyplanet.jp> |
---|---|
date | Wed, 05 May 2010 18:26:06 +0900 |
parents | |
children |
line wrap: on
line source
/* * Copyright 2009 Paula Stanciu * * This file is part of Audacious. * * Audacious 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, version 3 of the License. * * Audacious 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 * Audacious. If not, see <http://www.gnu.org/licenses/>. * * The Audacious team does not consider modular code linking to Audacious or * using our public API to be a derived work. */ /* this stuff may be moved to ../util.h if needed by other formats */ #include <inttypes.h> #include "audlegacy/vfs.h" #include "../util.h" #include "guid.h" #include "wma_fmt.h" GUID *guid_read_from_file(VFSFile * f) { GUID temp; if ((f == NULL) || (vfs_fread(&temp, sizeof(GUID), 1, f) != 1)) return NULL; temp.le32 = GUINT32_FROM_LE(temp.le32); temp.le16_1 = GUINT16_FROM_LE(temp.le16_1); temp.le16_2 = GUINT16_FROM_LE(temp.le16_2); temp.be64 = GUINT64_FROM_BE(temp.be64); return g_memdup(&temp, sizeof(GUID)); } gboolean guid_write_to_file(VFSFile * f, int guid_type) { g_return_val_if_fail(f != NULL, FALSE); GUID *g = guid_convert_from_string(wma_guid_map(guid_type)); gboolean ret = write_LEuint32(f, g->le32) && write_LEuint16(f, g->le16_1) && write_LEuint16(f, g->le16_1) && write_LEuint64(f, g->be64); g_free(g); return ret; } GUID *guid_convert_from_string(const gchar * string) { GUID temp; if (sscanf(string, "%" SCNx32 "-%" SCNx16 "-%" SCNx16 "-%" SCNx64, &temp.le32, &temp.le16_1, &temp.le16_2, &temp.be64) != 4) return NULL; return g_memdup(&temp, sizeof(GUID)); } gchar *guid_convert_to_string(const GUID * g) { return g_strdup_printf("%8x-%hx-%hx-%" PRIx64 "\n", GUINT32_TO_LE(g->le32), GUINT16_TO_LE(g->le16_1), GUINT16_TO_LE(g->le16_2), GUINT64_TO_BE(g->be64)); } gboolean guid_equal(GUID * g1, GUID * g2) { /* AUDDBG("GUID 1 = %8x-%hx-%hx-%"PRIx64"\n", g1->le32, g1->le16_1, g1->le16_2, g1->be64); AUDDBG("GUID 2 = %8x-%hx-%hx-%"PRIx64"\n", g2->le32, g2->le16_1, g2->le16_2, g2->be64); */ g_return_val_if_fail((g1 != NULL) && (g2 != NULL), FALSE); if (!memcmp(g1, g2, 16)) { // AUDDBG("equal\n"); return TRUE; } /* AUDDBG("not equal\n"); */ return FALSE; } int get_guid_type(GUID * g) { GUID *g1; int i; for (i = 0; i < ASF_OBJECT_LAST - 1; i++) { g1 = guid_convert_from_string(wma_guid_map(i)); if (guid_equal(g, g1)) { g_free(g1); return i; } } return -1; } const gchar *wma_guid_map(int i) { const gchar *_guid_map[ASF_OBJECT_LAST] = { ASF_HEADER_OBJECT_GUID, ASF_FILE_PROPERTIES_OBJECT_GUID, ASF_STREAM_PROPERTIES_OBJECT_GUID, ASF_HEADER_EXTENSION_OBJECT_GUID, ASF_CODEC_LIST_OBJECT_GUID, ASF_SCRIPT_COMMAND_OBJECT_GUID, ASF_MARKER_OBJECT_GUID, ASF_BITRATE_MUTUAL_EXCLUSION_OBJECT_GUID, ASF_ERROR_CORRECTION_OBJECT_GUID, ASF_CONTENT_DESCRIPTION_OBJECT_GUID, ASF_EXTENDED_CONTENT_DESCRIPTION_OBJECT_GUID, ASF_CONTENT_BRANDING_OBJECT_GUID, ASF_STREAM_BITRATE_PROPERTIES_OBJECT_GUID, ASF_CONTENT_ENCRYPTION_OBJECT_GUID, ASF_EXTENDED_CONTENT_ENCRYPTION_OBJECT_GUID, ASF_DIGITAL_SIGNATURE_OBJECT_GUID, ASF_PADDING_OBJECT_GUID }; return _guid_map[i]; }