2.0.0-rc (#9)
### Issues
* \#1 \[bug\] Unable to mount S3 due to 'item_not_found' exception
* \#2 Require bucket name for S3 mounts
* \#3 \[bug\] File size is not being updated in S3 mount
* \#4 Upgrade to libfuse-3.x.x
* \#5 Switch to renterd for Sia support
* \#6 Switch to cpp-httplib to further reduce dependencies
* \#7 Remove global_data and calculate used disk space per provider
* \#8 Switch to libcurl for S3 mount support
### Changes from v1.x.x
* Added read-only encrypt provider
  * Pass-through mount point that transparently encrypts source data using `XChaCha20-Poly1305`
* Added S3 encryption support via `XChaCha20-Poly1305`
* Added replay protection to remote mounts
* Added support base64 writes in remote FUSE
* Created static linked Linux binaries for `amd64` and `aarch64` using `musl-libc`
* Removed legacy Sia renter support
* Removed Skynet support
* Fixed multiple remote mount WinFSP API issues on \*NIX servers
* Implemented chunked read and write
  * Writes for non-cached files are performed in chunks of 8Mib
* Removed `repertory-ui` support
* Removed `FreeBSD` support
* Switched to `libsodium` over `CryptoPP`
* Switched to `XChaCha20-Poly1305` for remote mounts
* Updated `GoogleTest` to v1.14.0
* Updated `JSON for Modern C++` to v3.11.2
* Updated `OpenSSL` to v1.1.1w
* Updated `RocksDB` to v8.5.3
* Updated `WinFSP` to 2023
* Updated `boost` to v1.78.0
* Updated `cURL` to v8.3.0
* Updated `zlib` to v1.3
* Use `upload_manager` for all providers
  * Adds a delay to uploads to prevent excessive API calls
  * Supports re-upload after mount restart for incomplete uploads
  * NOTE: Uploads for all providers are full file (no resume support)
    * Multipart upload support is planned for S3
Reviewed-on: #9
			
			
This commit is contained in:
		
							
								
								
									
										72
									
								
								3rd_party/pugixml/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								3rd_party/pugixml/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | ||||
| pugixml [](https://github.com/zeux/pugixml/actions) [](https://ci.appveyor.com/project/zeux/pugixml) [](https://codecov.io/github/zeux/pugixml?branch=master)  | ||||
| ======= | ||||
|  | ||||
| pugixml is a C++ XML processing library, which consists of a DOM-like interface with rich traversal/modification | ||||
| capabilities, an extremely fast XML parser which constructs the DOM tree from an XML file/buffer, and an XPath 1.0 | ||||
| implementation for complex data-driven tree queries. Full Unicode support is also available, with Unicode interface | ||||
| variants and conversions between different Unicode encodings (which happen automatically during parsing/saving). | ||||
|  | ||||
| pugixml is used by a lot of projects, both open-source and proprietary, for performance and easy-to-use interface. | ||||
|  | ||||
| ## Documentation | ||||
|  | ||||
| Documentation for the current release of pugixml is available on-line as two separate documents: | ||||
|  | ||||
| * [Quick-start guide](https://pugixml.org/docs/quickstart.html), that aims to provide enough information to start using the library; | ||||
| * [Complete reference manual](https://pugixml.org/docs/manual.html), that describes all features of the library in detail. | ||||
|  | ||||
| You’re advised to start with the quick-start guide; however, many important library features are either not described in it at all or only mentioned briefly; if you require more information you should read the complete manual. | ||||
|  | ||||
| ## Example | ||||
|  | ||||
| Here's an example of how code using pugixml looks; it opens an XML file, goes over all Tool nodes and prints tools that have a Timeout attribute greater than 0: | ||||
|  | ||||
| ```c++ | ||||
| #include "pugixml.hpp" | ||||
| #include <iostream> | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     pugi::xml_document doc; | ||||
|     pugi::xml_parse_result result = doc.load_file("xgconsole.xml"); | ||||
|     if (!result) | ||||
|         return -1; | ||||
|          | ||||
|     for (pugi::xml_node tool: doc.child("Profile").child("Tools").children("Tool")) | ||||
|     { | ||||
|         int timeout = tool.attribute("Timeout").as_int(); | ||||
|          | ||||
|         if (timeout > 0) | ||||
|             std::cout << "Tool " << tool.attribute("Filename").value() << " has timeout " << timeout << "\n"; | ||||
|     } | ||||
| } | ||||
| ``` | ||||
|  | ||||
| And the same example using XPath: | ||||
|  | ||||
| ```c++ | ||||
| #include "pugixml.hpp" | ||||
| #include <iostream> | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     pugi::xml_document doc; | ||||
|     pugi::xml_parse_result result = doc.load_file("xgconsole.xml"); | ||||
|     if (!result) | ||||
|         return -1; | ||||
|          | ||||
|     pugi::xpath_node_set tools_with_timeout = doc.select_nodes("/Profile/Tools/Tool[@Timeout > 0]"); | ||||
|      | ||||
|     for (pugi::xpath_node node: tools_with_timeout) | ||||
|     { | ||||
|         pugi::xml_node tool = node.node(); | ||||
|         std::cout << "Tool " << tool.attribute("Filename").value() << | ||||
|             " has timeout " << tool.attribute("Timeout").as_int() << "\n"; | ||||
|     } | ||||
| } | ||||
| ``` | ||||
|  | ||||
|  | ||||
| ## License | ||||
|  | ||||
| This library is available to anybody free of charge, under the terms of MIT License (see LICENSE.md). | ||||
		Reference in New Issue
	
	Block a user