| Age | Commit message (Collapse) | Author | Files | Lines | 
|---|
|  |  | 
|  | This reverts commit a91f5740d100414a76959714b819422ee5b2d8a8. | 
|  |  | 
|  | This makes it more obvious that it is arbitrary data and not necessarily
a string value. | 
|  |  | 
|  | Credit to OSS-Fuzz | 
|  | Thanks to @tihmstar for pointing this out! | 
|  | Thanks @beyonik for pointing this out! | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | plist_read_from_file() is a convenience function that will open a
given file, checks its size, allocates a buffer large enough to
hold the full contents, and reads from file to fill the buffer.
Then, it calls plist_from_memory() to convert the data to plist
format.
A (breaking) change had to be made so that plist_from_memory() will
also return the parsed format in its 4th argument (if non-NULL). | 
|  | This commit introduces constants for the different plist formats,
and adds 3 new human-readable output-only formats:
- PLIST_FORMAT_PRINT: the default human-readable format
- PLIST_FORMAT_LIMD: "libimobiledevice" format (used in ideviceinfo)
- PLIST_FORMAT_PLUTIL: plutil-style format
Also, a new set of write functions has been added:
- plist_write_to_string
- plist_write_to_stream
- plist_write_to_file
Plus a simple "dump" function:
- plist_print
See documentation for details. | 
|  | the format parses
This makes the `-d` option work in plistutil that wasn't doing anything | 
|  | This makes the code more readable. Obviously all the code that uses it
is also updated. | 
|  | The problem was that we swapped potential child node data between nodes,
but their parents would not be updated that way, leading to double frees
or segmentation faults when freeing a plist. This commit instead fixes this
by swapping the actual nodes in the tree. | 
|  |  | 
|  |  | 
|  | This properly supports getting and setting signed or unsigned integer values.
Also, a new helper function plist_int_val_is_negative() was added to determine if
a given #PLIST_INT node has a negative value or not.
The old type PLIST_UINT is defined as a macro with the value of PLIST_INT for
backwards compatibility.
This commit also adds int vs. uint support to the C++ interface, and the python
bindings in a hopefully useful way. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | This way it can be easier determined why an import/export operation failed
instead of just having a NULL result. | 
|  |  | 
|  | Thanks to @azerg for bringing this to my attention.
Instead of having multiple (internally identical) plist_*_free() functions,
this commit introduces a single plist_mem_free() that can be used to free
the memory allocated by plist_to_xml(), plist_to_bin(), plist_get_key_val(),
plist_get_string_val(), and plist_get_data_val().
Note: This commit REMOVES plist_to_bin_free() and plist_to_xml_free(). | 
|  | of DllMain | 
|  | thread_once_t globals | 
|  | Found with google-readability-casting
Signed-off-by: Rosen Penev <rosenp@gmail.com> | 
|  | Found with cppcoreguidelines-avoid-non-const-global-variables
Signed-off-by: Rosen Penev <rosenp@gmail.com> | 
|  | The const is actually misplaced. const plist_t evaluates to void *const
instead of const void *. const qualification of the former makes no
sense in function declarations.
Found with misc-misplaced-const
Signed-off-by: Rosen Penev <rosenp@gmail.com> | 
|  | [clang-tidy] Found with readability-else-after-return
Signed-off-by: Rosen Penev <rosenp@gmail.com> | 
|  |  | 
|  | [clang-tidy] Found with readability-redundant-control-flow
Signed-off-by: Rosen Penev <rosenp@gmail.com> | 
|  | a PLIST_BOOLEAN | 
|  | This will prevent an assert if a NULL pointer is passed, and can make
writing some code easier and cleaner without the need for a NULL check.
For example, plist_copy(plist_dict_get_item(dict, "abc")) would give us
a copy of the dict's node if the dict has a value for the given key, or
NULL without any further checks. | 
|  |  | 
|  |  | 
|  | types
... except container node types like PLIST_ARRAY or PLIST_DICT. | 
|  |  | 
|  |  | 
|  | As mentioned in #142, plist_copy_node() was not correctly handling the hash
tables when cloning array or dict nodes; it incorrectly filled the hash table
with the original child node info, which effectively would lead to a
segmentation fault / UaF if the original array/dict would be freed followed
by an attempt to access an element in the new hash table. | 
|  | PLIST_DICT | 
|  | item of a #PLIST_DICT | 
|  | without relying on the index | 
|  | be found | 
|  |  | 
|  | Also fixes #126 by skipping the strlen() in the assert() if for some reason NULL is returned as data |