| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  |  * 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, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-17 18:59:41 +00:00
										 |  |  | #pragma once
 | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup bli | 
					
						
							|  |  |  |  * \brief A general argument parsing module. | 
					
						
							| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-02 15:04:53 +01:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  | struct bArgs; | 
					
						
							|  |  |  | typedef struct bArgs bArgs; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-04 20:47:12 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Returns the number of extra arguments consumed by the function. | 
					
						
							|  |  |  |  * -  0 is normal value, | 
					
						
							|  |  |  |  * - -1 stops parsing arguments, other negative indicates skip | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | typedef int (*BA_ArgCallback)(int argc, const char **argv, void *data); | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 10:29:06 +11:00
										 |  |  | struct bArgs *BLI_args_create(int argc, const char **argv); | 
					
						
							|  |  |  | void BLI_args_destroy(struct bArgs *ba); | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 10:29:06 +11:00
										 |  |  | /** The pass to use for #BLI_args_add. */ | 
					
						
							|  |  |  | void BLI_args_pass_set(struct bArgs *ba, int current_pass); | 
					
						
							| 
									
										
										
										
											2020-10-28 12:34:33 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-04 20:47:12 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Pass starts at 1, -1 means valid all the time | 
					
						
							| 
									
										
										
										
											2010-05-24 18:53:45 +00:00
										 |  |  |  * short_arg or long_arg can be null to specify no short or long versions | 
					
						
							| 
									
										
										
										
											2012-07-04 20:47:12 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-11-06 10:29:06 +11:00
										 |  |  | void BLI_args_add(struct bArgs *ba, | 
					
						
							|  |  |  |                   const char *short_arg, | 
					
						
							|  |  |  |                   const char *long_arg, | 
					
						
							|  |  |  |                   const char *doc, | 
					
						
							|  |  |  |                   BA_ArgCallback cb, | 
					
						
							|  |  |  |                   void *data); | 
					
						
							| 
									
										
										
										
											2012-07-04 20:47:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Short_case and long_case specify if those arguments are case specific | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-11-06 10:29:06 +11:00
										 |  |  | void BLI_args_add_case(struct bArgs *ba, | 
					
						
							|  |  |  |                        const char *short_arg, | 
					
						
							|  |  |  |                        int short_case, | 
					
						
							|  |  |  |                        const char *long_arg, | 
					
						
							|  |  |  |                        int long_case, | 
					
						
							|  |  |  |                        const char *doc, | 
					
						
							|  |  |  |                        BA_ArgCallback cb, | 
					
						
							|  |  |  |                        void *data); | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 10:29:06 +11:00
										 |  |  | void BLI_args_parse(struct bArgs *ba, int pass, BA_ArgCallback default_cb, void *data); | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 10:29:06 +11:00
										 |  |  | void BLI_args_print_arg_doc(struct bArgs *ba, const char *arg); | 
					
						
							|  |  |  | void BLI_args_print_other_doc(struct bArgs *ba); | 
					
						
							| 
									
										
										
										
											2010-05-24 18:53:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 10:29:06 +11:00
										 |  |  | void BLI_args_print(struct bArgs *ba); | 
					
						
							| 
									
										
										
										
											2010-02-01 01:43:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-02 15:04:53 +01:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 |