| 
									
										
										
										
											2014-08-13 19:20:17 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * QAPI util functions | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Authors: | 
					
						
							|  |  |  |  *  Hu Tao       <hutao@cn.fujitsu.com> | 
					
						
							|  |  |  |  *  Peter Lieven <pl@kamp.de> | 
					
						
							|  |  |  |  *  | 
					
						
							|  |  |  |  * This work is licensed under the terms of the GNU LGPL, version 2.1 or later. | 
					
						
							|  |  |  |  * See the COPYING.LIB file in the top-level directory. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-29 17:49:57 +00:00
										 |  |  | #include "qemu/osdep.h"
 | 
					
						
							| 
									
										
											  
											
												include/qemu/osdep.h: Don't include qapi/error.h
Commit 57cb38b included qapi/error.h into qemu/osdep.h to get the
Error typedef.  Since then, we've moved to include qemu/osdep.h
everywhere.  Its file comment explains: "To avoid getting into
possible circular include dependencies, this file should not include
any other QEMU headers, with the exceptions of config-host.h,
compiler.h, os-posix.h and os-win32.h, all of which are doing a
similar job to this file and are under similar constraints."
qapi/error.h doesn't do a similar job, and it doesn't adhere to
similar constraints: it includes qapi-types.h.  That's in excess of
100KiB of crap most .c files don't actually need.
Add the typedef to qemu/typedefs.h, and include that instead of
qapi/error.h.  Include qapi/error.h in .c files that need it and don't
get it now.  Include qapi-types.h in qom/object.h for uint16List.
Update scripts/clean-includes accordingly.  Update it further to match
reality: replace config.h by config-target.h, add sysemu/os-posix.h,
sysemu/os-win32.h.  Update the list of includes in the qemu/osdep.h
comment quoted above similarly.
This reduces the number of objects depending on qapi/error.h from "all
of them" to less than a third.  Unfortunately, the number depending on
qapi-types.h shrinks only a little.  More work is needed for that one.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
[Fix compilation without the spice devel packages. - Paolo]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
											
										 
											2016-03-14 09:01:28 +01:00
										 |  |  | #include "qapi/error.h"
 | 
					
						
							| 
									
										
										
										
											2014-08-13 19:20:17 +02:00
										 |  |  | #include "qemu-common.h"
 | 
					
						
							|  |  |  | #include "qapi/util.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-13 17:14:07 +01:00
										 |  |  | int qapi_enum_parse(const char * const lookup[], const char *buf, | 
					
						
							| 
									
										
										
										
											2014-08-13 19:20:17 +02:00
										 |  |  |                     int max, int def, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     int i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!buf) { | 
					
						
							|  |  |  |         return def; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (i = 0; i < max; i++) { | 
					
						
							|  |  |  |         if (!strcmp(buf, lookup[i])) { | 
					
						
							|  |  |  |             return i; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     error_setg(errp, "invalid parameter value: %s", buf); | 
					
						
							|  |  |  |     return def; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2017-02-28 22:27:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Parse a valid QAPI name from @str. | 
					
						
							|  |  |  |  * A valid name consists of letters, digits, hyphen and underscore. | 
					
						
							|  |  |  |  * It may be prefixed by __RFQDN_ (downstream extension), where RFQDN | 
					
						
							|  |  |  |  * may contain only letters, digits, hyphen and period. | 
					
						
							|  |  |  |  * The special exception for enumeration names is not implemented. | 
					
						
							|  |  |  |  * See docs/qapi-code-gen.txt for more on QAPI naming rules. | 
					
						
							|  |  |  |  * Keep this consistent with scripts/qapi.py! | 
					
						
							|  |  |  |  * If @complete, the parse fails unless it consumes @str completely. | 
					
						
							|  |  |  |  * Return its length on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int parse_qapi_name(const char *str, bool complete) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const char *p = str; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (*p == '_') {            /* Downstream __RFQDN_ */ | 
					
						
							|  |  |  |         p++; | 
					
						
							|  |  |  |         if (*p != '_') { | 
					
						
							|  |  |  |             return -1; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         while (*++p) { | 
					
						
							|  |  |  |             if (!qemu_isalnum(*p) && *p != '-' && *p != '.') { | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (*p != '_') { | 
					
						
							|  |  |  |             return -1; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         p++; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!qemu_isalpha(*p)) { | 
					
						
							|  |  |  |         return -1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     while (*++p) { | 
					
						
							|  |  |  |         if (!qemu_isalnum(*p) && *p != '-' && *p != '_') { | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (complete && *p) { | 
					
						
							|  |  |  |         return -1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return p - str; | 
					
						
							|  |  |  | } |