view src/imgstore.h @ 10559:c354b70d8502

[gaim-migrate @ 11937] (09:14:16) LSchiere2: um, my new tabs are appearing on the wrong size (09:14:20) LSchiere2: s/size/side/ (09:14:24) LSchiere2: and i can't drag and drop them (09:15:01) SeanEgn: Unimportant! It's coming out ;) (09:15:11) SeanEgn: But, yeah, the wrong size was just a silly mistake (09:17:07) LSchiere2: and control-tab is backwards also (09:17:28) SeanEgn: well, actually ctrl-tab is the correct direction. (09:17:40) SeanEgn: But because the tabs are in the wrong direction, it seems to go the wrong way. (09:17:52) SeanEgn: But it does indeed go from tab 0 to tab 1 to tab 2. (09:18:06) LSchiere2: i see (09:19:29) SeanEgn: Actually, it might be a GTK bug (09:20:06) LSchiere2: i am displeased (09:20:13) SeanEgn: but if you change GTK_PACK_END to GTK_PACK_START, in gtk_notebook_set_tab_label_packing(), it should probably change. (09:20:17) LSchiere2: on a side note, i do not remember gtk being in the list of upgraded packages (09:20:23) SeanEgn: I would assume the way we want it is _END (09:20:44) SeanEgn: no, it's new code that I added that's causing this. (09:21:00) LSchiere2: which file? (09:21:04) SeanEgn: The "bug" is symantic. I would expect GTK_PACK_END to pack new tabs to the right of everything. (09:21:05) SeanEgn: gtkconv.c (09:21:16) SeanEgn: because that's what packing in the end ususally does. (09:21:25) SeanEgn: here it seems to pack to the left of everything. committer: Tailor Script <tailor@pidgin.im>
author Luke Schierer <lschiere@pidgin.im>
date Mon, 31 Jan 2005 14:36:26 +0000
parents db62420a53a2
children
line wrap: on
line source

/**
 * @file imgstore.h IM Image Store API
 * @ingroup core
 *
 * gaim
 *
 * Gaim is the legal property of its developers, whose names are too numerous
 * to list here.  Please refer to the COPYRIGHT file distributed with this
 * source distribution.
 *
 * 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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 */
#ifndef _GAIM_IMGSTORE_H_
#define _GAIM_IMGSTORE_H_

struct _GaimStoredImage;
typedef struct _GaimStoredImage GaimStoredImage;

#ifdef __cplusplus
extern "C" {
#endif

/**
 * Add an image to the store. The caller owns a reference
 * to the image in the store, and must dereference the image
 * with gaim_imgstore_unref for it to be freed.
 *
 * @param data		Pointer to the image data.
 * @param size		Image data's size.
 * @param filename	Filename associated with image.

 * @return ID for the image.
 */
int gaim_imgstore_add(const void *data, size_t size, const char *filename);

/**
 * Retrieve an image from the store. The caller does not own a
 * reference to the image.
 *
 * @param id		The ID for the image.
 *
 * @return A pointer to the requested image, or NULL if it was not found.
 */
GaimStoredImage *gaim_imgstore_get(int id);

/**
 * Retrieves a pointer to the image's data.
 *
 * @param i	The Image
 *
 * @return A pointer to the data, which must not
 *         be freed or modified.
 */
gpointer gaim_imgstore_get_data(GaimStoredImage *i);

/**
 * Retrieves the length of the image's data.
 *
 * @param i	The Image
 *
 * @return The size of the data that the pointer returned by
 *         gaim_imgstore_get_data points to.
 */
size_t gaim_imgstore_get_size(GaimStoredImage *i);

/**
 * Retrieves a pointer to the image's filename.
 *
 * @param i	The Image
 *
 * @return A pointer to the filename, which must not
 *         be freed or modified.
 */
const char *gaim_imgstore_get_filename(GaimStoredImage *i);

/**
 * Increment the reference count for an image in the store. The
 * image will be removed from the store when the reference count
 * is zero.
 *
 * @param id		The ID for the image.
 */
void gaim_imgstore_ref(int id);

/**
 * Decrement the reference count for an image in the store. The
 * image will be removed from the store when the reference count
 * is zero.
 *
 * @param id		The ID for the image.
 */
void gaim_imgstore_unref(int id);

#ifdef __cplusplus
}
#endif

#endif /* _GAIM_IMGSTORE_H_ */