api: improve api string safety
[vpp.git] / src / vlibapi / api_types.h
index 759298e..21fcde5 100644 (file)
 #ifndef included_api_types_h
 #define included_api_types_h
 
+#include <stdbool.h>
+#include <stdarg.h>
 #include <vppinfra/types.h>
+#include <arpa/inet.h>
+#include <string.h>
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
 
 /* VPP API string type */
 typedef struct
@@ -29,26 +38,22 @@ typedef struct
   u8 buf[0];
 } __attribute__ ((packed)) vl_api_string_t;
 
-static inline int
-vl_api_to_api_string (u32 len, const char *buf, vl_api_string_t * str)
-{
-  if (strncpy_s ((char *) str->buf, len, buf, len - 1) != 0)
-    len = 0;
-  str->length = clib_host_to_net_u32 (len);
-  return len + sizeof (u32);
-}
+/* Nul terminated string to vl_api_string_t */
+extern int vl_api_c_string_to_api_string (const char *buf, vl_api_string_t * str);
+/* NON nul terminated vector to vl_api_string_t */
+extern int vl_api_vec_to_api_string (const u8 *vec, vl_api_string_t * str);
 
-/* Return a C string from API string */
-static inline u8 *
-vl_api_from_api_string (vl_api_string_t * astr)
-{
-  return astr->buf;
-}
+extern u32 vl_api_string_len (vl_api_string_t * astr);
 
-static inline u32
-vl_api_string_len (vl_api_string_t * astr)
-{
-  return clib_net_to_host_u32 (astr->length);
+/* Returns new vector. NON nul terminated */
+extern u8 * vl_api_from_api_to_new_vec (vl_api_string_t *astr);
+/* Returns new vector. Nul terminated */
+extern char * vl_api_from_api_to_new_c_string (vl_api_string_t *astr);
+
+extern u8 *vl_api_format_string (u8 *s, va_list *args);
+
+#ifdef __cplusplus
 }
+#endif
 
 #endif