| 
									
										
										
										
											2011-02-18 13:05:18 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): none yet. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-17 18:59:41 +00:00
										 |  |  | #ifndef __BKE_IDCODE_H__
 | 
					
						
							|  |  |  | #define __BKE_IDCODE_H__
 | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-18 13:05:18 +00:00
										 |  |  | /** \file BKE_idcode.h
 | 
					
						
							|  |  |  |  *  \ingroup bke | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Convert an idcode into a name. | 
					
						
							|  |  |  |  *  | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * \param code The code to convert. | 
					
						
							|  |  |  |  * \return A static string representing the name of | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  |  * the code. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | const char *BKE_idcode_to_name(int code); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Convert an idcode into a name (plural). | 
					
						
							|  |  |  |  *  | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * \param code The code to convert. | 
					
						
							|  |  |  |  * \return A static string representing the name of | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  |  * the code. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | const char *BKE_idcode_to_name_plural(int code); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Convert a name into an idcode (ie. ID_SCE) | 
					
						
							|  |  |  |  *  | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * \param name The name to convert. | 
					
						
							|  |  |  |  * \return The code for the name, or 0 if invalid. | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | int BKE_idcode_from_name(const char *name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Return non-zero when an ID type is linkable. | 
					
						
							|  |  |  |  *  | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * \param code The code to check. | 
					
						
							|  |  |  |  * \return Boolean, 0 when non linkable. | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | int BKE_idcode_is_linkable(int code); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Return if the ID code is a valid ID code. | 
					
						
							|  |  |  |  *  | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * \param code The code to check. | 
					
						
							|  |  |  |  * \return Boolean, 0 when invalid. | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | int BKE_idcode_is_valid(int code); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-12 14:38:00 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Return an ID code and steps the index forward 1. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-03-02 16:05:54 +00:00
										 |  |  |  * \param index start as 0. | 
					
						
							|  |  |  |  * \return the code, 0 when all codes have been returned. | 
					
						
							| 
									
										
										
										
											2011-03-12 14:38:00 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | int BKE_idcode_iter_step(int *index); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-10 15:14:19 +00:00
										 |  |  | #endif
 |