commit | feb0bcd102ff0abc34ffa04e8cabf26706ffdb38 | [log] [tgz] |
---|---|---|
author | liujianfengv <27178254@qq.com> | Sat Jun 26 11:43:42 2021 +0800 |
committer | Nikias Bassen <nikias@gmx.li> | Tue Jul 13 12:46:38 2021 +0200 |
tree | 5a25275b1f3ffd9b5a0190257a7f2a2d9ab39d76 | |
parent | 48f7d8439f2bf7a9df19b8cda19e224efd3a56b1 [diff] |
cpp: Array: Make sure the array passed to array_fill ist passed by reference When creating a new Array object, for example through PList::Node::FromPlist(plist_t node), the array_fill function is called from Array() constructor in line 51. It seems that the intended way of calling array_fill() is to pass the _array object by reference, however it is actually passed by value. Thus the changes to the array object made by array_fill() are discarded when the function returns. This commit passes the _array by reference so we keep the changes.
A small portable C library to handle Apple Property List files in binary or XML format.
The project provides an interface to read and write plist files in binary or XML format alongside a command-line utility named plistutil
.
Some key features are:
plistutil
utility for the command-lineFirst install all required dependencies and build tools:
sudo apt-get install \ build-essential \ checkinstall \ git \ autoconf \ automake \ libtool-bin
If you want to optionally build the documentation or Python bindings use:
sudo apt-get install \ doxygen \ cython
Then clone the actual project repository:
git clone https://github.com/libimobiledevice/libplist.git cd libplist
Now you can build and install it:
./autogen.sh make sudo make install
Then simply run:
plistutil -i foobar.plist -o output.plist
This converts the foobar.plist
file to the opposite format, e.g. binary to XML or vice versa, and outputs it to the output.plist
file.
Please consult the usage information or manual page for a full documentation of available command line options:
plistutil --help man plistutil
We welcome contributions from anyone and are grateful for every pull request!
If you'd like to contribute, please fork the master
branch, change, commit and send a pull request for review. Once approved it can be merged into the main code base.
If you plan to contribute larger changes or a major refactoring, please create a ticket first to discuss the idea upfront to ensure less effort for everyone.
Please make sure your contribution adheres to:
We are still working on the guidelines so bear with us!
This project is licensed under the GNU Lesser General Public License v2.1, also included in the repository in the COPYING
file.
Apple, iPhone, iPad, iPod, iPod Touch, Apple TV, Apple Watch, Mac, iOS, iPadOS, tvOS, watchOS, and macOS are trademarks of Apple Inc.
This project is an independent software library and has not been authorized, sponsored, or otherwise approved by Apple Inc.
README Updated on: 2020-06-12