summaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorGravatar Christophe Fergeau2016-05-12 02:52:50 +0200
committerGravatar Nikias Bassen2016-05-12 02:52:50 +0200
commit449e27bf754f903f856a741e163a9e4a0c8037b0 (patch)
tree209201532a9ba1c255c412a9f3257fd078d17091 /include
parent19735fbd32ddbc9874f8aca12ac6e86239441dcd (diff)
downloadlibplist-449e27bf754f903f856a741e163a9e4a0c8037b0.tar.gz
libplist-449e27bf754f903f856a741e163a9e4a0c8037b0.tar.bz2
Add plist_is_binary()
It can be useful if one needs to know what type of plist a memory buffer contains.
Diffstat (limited to 'include')
-rw-r--r--include/plist/plist.h13
1 files changed, 13 insertions, 0 deletions
diff --git a/include/plist/plist.h b/include/plist/plist.h
index acd1c4d..2b7e1a1 100644
--- a/include/plist/plist.h
+++ b/include/plist/plist.h
@@ -616,6 +616,19 @@ extern "C"
*/
void plist_from_bin(const char *plist_bin, uint32_t length, plist_t * plist);
+ /**
+ * Test if in-memory plist data is binary or XML
+ * This method will look at the first bytes of plist_data
+ * to determine if plist_data contains a binary or XML plist.
+ * This method is not validating the whole memory buffer to check if the
+ * content is truly a plist, it's only using some heuristic on the first few
+ * bytes of plist_data.
+ *
+ * @param plist_data a pointer to the memory buffer containing plist data.
+ * @param length length of the buffer to read.
+ * @return 1 if the buffer is a binary plist, 0 otherwise.
+ */
+ int plist_is_binary(const char *plist_data, uint32_t length);
/********************************************
* *