diff --git a/SabreTools.Helper/SabreTools.Helper.csproj b/SabreTools.Helper/SabreTools.Helper.csproj
index 283bacde..63324ec8 100644
--- a/SabreTools.Helper/SabreTools.Helper.csproj
+++ b/SabreTools.Helper/SabreTools.Helper.csproj
@@ -96,6 +96,9 @@
..\packages\Mono.Data.Sqlite.Portable.1.0.3.5\lib\net4\System.Transactions.Portable.dll
True
+
+ ..\packages\System.ValueTuple.4.3.0\lib\netstandard1.0\System.ValueTuple.dll
+
diff --git a/SabreTools.Helper/packages.config b/SabreTools.Helper/packages.config
index a145542b..57f103dd 100644
--- a/SabreTools.Helper/packages.config
+++ b/SabreTools.Helper/packages.config
@@ -4,4 +4,5 @@
+
\ No newline at end of file
diff --git a/packages/System.ValueTuple.4.3.0/System.ValueTuple.4.3.0.nupkg b/packages/System.ValueTuple.4.3.0/System.ValueTuple.4.3.0.nupkg
new file mode 100644
index 00000000..10173d6d
Binary files /dev/null and b/packages/System.ValueTuple.4.3.0/System.ValueTuple.4.3.0.nupkg differ
diff --git a/packages/System.ValueTuple.4.3.0/ThirdPartyNotices.txt b/packages/System.ValueTuple.4.3.0/ThirdPartyNotices.txt
new file mode 100644
index 00000000..55cfb208
--- /dev/null
+++ b/packages/System.ValueTuple.4.3.0/ThirdPartyNotices.txt
@@ -0,0 +1,31 @@
+This Microsoft .NET Library may incorporate components from the projects listed
+below. Microsoft licenses these components under the Microsoft .NET Library
+software license terms. The original copyright notices and the licenses under
+which Microsoft received such components are set forth below for informational
+purposes only. Microsoft reserves all rights not expressly granted herein,
+whether by implication, estoppel or otherwise.
+
+1. .NET Core (https://github.com/dotnet/core/)
+
+.NET Core
+Copyright (c) .NET Foundation and Contributors
+
+The MIT License (MIT)
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
\ No newline at end of file
diff --git a/packages/System.ValueTuple.4.3.0/dotnet_library_license.txt b/packages/System.ValueTuple.4.3.0/dotnet_library_license.txt
new file mode 100644
index 00000000..92b6c443
--- /dev/null
+++ b/packages/System.ValueTuple.4.3.0/dotnet_library_license.txt
@@ -0,0 +1,128 @@
+
+MICROSOFT SOFTWARE LICENSE TERMS
+
+
+MICROSOFT .NET LIBRARY
+
+These license terms are an agreement between Microsoft Corporation (or based on where you live, one of its affiliates) and you. Please read them. They apply to the software named above, which includes the media on which you received it, if any. The terms also apply to any Microsoft
+
+· updates,
+
+· supplements,
+
+· Internet-based services, and
+
+· support services
+
+for this software, unless other terms accompany those items. If so, those terms apply.
+
+BY USING THE SOFTWARE, YOU ACCEPT THESE TERMS. IF YOU DO NOT ACCEPT THEM, DO NOT USE THE SOFTWARE.
+
+
+IF YOU COMPLY WITH THESE LICENSE TERMS, YOU HAVE THE PERPETUAL RIGHTS BELOW.
+
+1. INSTALLATION AND USE RIGHTS.
+
+a. Installation and Use. You may install and use any number of copies of the software to design, develop and test your programs.
+
+b. Third Party Programs. The software may include third party programs that Microsoft, not the third party, licenses to you under this agreement. Notices, if any, for the third party program are included for your information only.
+
+2. ADDITIONAL LICENSING REQUIREMENTS AND/OR USE RIGHTS.
+
+a. DISTRIBUTABLE CODE. The software is comprised of Distributable Code. “Distributable Code” is code that you are permitted to distribute in programs you develop if you comply with the terms below.
+
+i. Right to Use and Distribute.
+
+· You may copy and distribute the object code form of the software.
+
+· Third Party Distribution. You may permit distributors of your programs to copy and distribute the Distributable Code as part of those programs.
+
+ii. Distribution Requirements. For any Distributable Code you distribute, you must
+
+· add significant primary functionality to it in your programs;
+
+· require distributors and external end users to agree to terms that protect it at least as much as this agreement;
+
+· display your valid copyright notice on your programs; and
+
+· indemnify, defend, and hold harmless Microsoft from any claims, including attorneys’ fees, related to the distribution or use of your programs.
+
+iii. Distribution Restrictions. You may not
+
+· alter any copyright, trademark or patent notice in the Distributable Code;
+
+· use Microsoft’s trademarks in your programs’ names or in a way that suggests your programs come from or are endorsed by Microsoft;
+
+· include Distributable Code in malicious, deceptive or unlawful programs; or
+
+· modify or distribute the source code of any Distributable Code so that any part of it becomes subject to an Excluded License. An Excluded License is one that requires, as a condition of use, modification or distribution, that
+
+· the code be disclosed or distributed in source code form; or
+
+· others have the right to modify it.
+
+3. SCOPE OF LICENSE. The software is licensed, not sold. This agreement only gives you some rights to use the software. Microsoft reserves all other rights. Unless applicable law gives you more rights despite this limitation, you may use the software only as expressly permitted in this agreement. In doing so, you must comply with any technical limitations in the software that only allow you to use it in certain ways. You may not
+
+· work around any technical limitations in the software;
+
+· reverse engineer, decompile or disassemble the software, except and only to the extent that applicable law expressly permits, despite this limitation;
+
+· publish the software for others to copy;
+
+· rent, lease or lend the software;
+
+· transfer the software or this agreement to any third party; or
+
+· use the software for commercial software hosting services.
+
+4. BACKUP COPY. You may make one backup copy of the software. You may use it only to reinstall the software.
+
+5. DOCUMENTATION. Any person that has valid access to your computer or internal network may copy and use the documentation for your internal, reference purposes.
+
+6. EXPORT RESTRICTIONS. The software is subject to United States export laws and regulations. You must comply with all domestic and international export laws and regulations that apply to the software. These laws include restrictions on destinations, end users and end use. For additional information, see www.microsoft.com/exporting.
+
+7. SUPPORT SERVICES. Because this software is “as is,” we may not provide support services for it.
+
+8. ENTIRE AGREEMENT. This agreement, and the terms for supplements, updates, Internet-based services and support services that you use, are the entire agreement for the software and support services.
+
+9. APPLICABLE LAW.
+
+a. United States. If you acquired the software in the United States, Washington state law governs the interpretation of this agreement and applies to claims for breach of it, regardless of conflict of laws principles. The laws of the state where you live govern all other claims, including claims under state consumer protection laws, unfair competition laws, and in tort.
+
+b. Outside the United States. If you acquired the software in any other country, the laws of that country apply.
+
+10. LEGAL EFFECT. This agreement describes certain legal rights. You may have other rights under the laws of your country. You may also have rights with respect to the party from whom you acquired the software. This agreement does not change your rights under the laws of your country if the laws of your country do not permit it to do so.
+
+11. DISCLAIMER OF WARRANTY. THE SOFTWARE IS LICENSED “AS-IS.” YOU BEAR THE RISK OF USING IT. MICROSOFT GIVES NO EXPRESS WARRANTIES, GUARANTEES OR CONDITIONS. YOU MAY HAVE ADDITIONAL CONSUMER RIGHTS OR STATUTORY GUARANTEES UNDER YOUR LOCAL LAWS WHICH THIS AGREEMENT CANNOT CHANGE. TO THE EXTENT PERMITTED UNDER YOUR LOCAL LAWS, MICROSOFT EXCLUDES THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
+
+FOR AUSTRALIA – YOU HAVE STATUTORY GUARANTEES UNDER THE AUSTRALIAN CONSUMER LAW AND NOTHING IN THESE TERMS IS INTENDED TO AFFECT THOSE RIGHTS.
+
+12. LIMITATION ON AND EXCLUSION OF REMEDIES AND DAMAGES. YOU CAN RECOVER FROM MICROSOFT AND ITS SUPPLIERS ONLY DIRECT DAMAGES UP TO U.S. $5.00. YOU CANNOT RECOVER ANY OTHER DAMAGES, INCLUDING CONSEQUENTIAL, LOST PROFITS, SPECIAL, INDIRECT OR INCIDENTAL DAMAGES.
+
+This limitation applies to
+
+· anything related to the software, services, content (including code) on third party Internet sites, or third party programs; and
+
+· claims for breach of contract, breach of warranty, guarantee or condition, strict liability, negligence, or other tort to the extent permitted by applicable law.
+
+It also applies even if Microsoft knew or should have known about the possibility of the damages. The above limitation or exclusion may not apply to you because your country may not allow the exclusion or limitation of incidental, consequential or other damages.
+
+Please note: As this software is distributed in Quebec, Canada, some of the clauses in this agreement are provided below in French.
+
+Remarque : Ce logiciel étant distribué au Québec, Canada, certaines des clauses dans ce contrat sont fournies ci-dessous en français.
+
+EXONÉRATION DE GARANTIE. Le logiciel visé par une licence est offert « tel quel ». Toute utilisation de ce logiciel est à votre seule risque et péril. Microsoft n’accorde aucune autre garantie expresse. Vous pouvez bénéficier de droits additionnels en vertu du droit local sur la protection des consommateurs, que ce contrat ne peut modifier. La ou elles sont permises par le droit locale, les garanties implicites de qualité marchande, d’adéquation à un usage particulier et d’absence de contrefaçon sont exclues.
+
+LIMITATION DES DOMMAGES-INTÉRÊTS ET EXCLUSION DE RESPONSABILITÉ POUR LES DOMMAGES. Vous pouvez obtenir de Microsoft et de ses fournisseurs une indemnisation en cas de dommages directs uniquement à hauteur de 5,00 $ US. Vous ne pouvez prétendre à aucune indemnisation pour les autres dommages, y compris les dommages spéciaux, indirects ou accessoires et pertes de bénéfices.
+
+Cette limitation concerne :
+
+· tout ce qui est relié au logiciel, aux services ou au contenu (y compris le code) figurant sur des sites Internet tiers ou dans des programmes tiers ; et
+
+· les réclamations au titre de violation de contrat ou de garantie, ou au titre de responsabilité stricte, de négligence ou d’une autre faute dans la limite autorisée par la loi en vigueur.
+
+Elle s’applique également, même si Microsoft connaissait ou devrait connaître l’éventualité d’un tel dommage. Si votre pays n’autorise pas l’exclusion ou la limitation de responsabilité pour les dommages indirects, accessoires ou de quelque nature que ce soit, il se peut que la limitation ou l’exclusion ci-dessus ne s’appliquera pas à votre égard.
+
+EFFET JURIDIQUE. Le présent contrat décrit certains droits juridiques. Vous pourriez avoir d’autres droits prévus par les lois de votre pays. Le présent contrat ne modifie pas les droits que vous confèrent les lois de votre pays si celles-ci ne le permettent pas.
+
+
diff --git a/packages/System.ValueTuple.4.3.0/lib/netstandard1.0/.xml b/packages/System.ValueTuple.4.3.0/lib/netstandard1.0/.xml
new file mode 100644
index 00000000..270d6efb
--- /dev/null
+++ b/packages/System.ValueTuple.4.3.0/lib/netstandard1.0/.xml
@@ -0,0 +1,1299 @@
+
+
+
+ System.ValueTuple
+
+
+
+
+ Indicates that the use of on a member is meant to be treated as a tuple with element names.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Specifies, in a pre-order depth-first traversal of a type's
+ construction, which occurrences are
+ meant to carry element names.
+
+
+ This constructor is meant to be used on types that contain an
+ instantiation of that contains
+ element names. For instance, if C is a generic type with
+ two type parameters, then a use of the constructed type C{, might be intended to
+ treat the first type argument as a tuple with element names and the
+ second as a tuple without element names. In which case, the
+ appropriate attribute specification should use a
+ transformNames value of { "name1", "name2", null, null,
+ null }.
+
+
+
+
+ Specifies, in a pre-order depth-first traversal of a type's
+ construction, which elements are
+ meant to carry element names.
+
+
+
+
+ Provides extension methods for instances to interop with C# tuples features (deconstruction syntax, converting from and to ).
+
+
+
+
+ Deconstruct a properly nested with 1 elements.
+
+
+
+
+ Deconstruct a properly nested with 2 elements.
+
+
+
+
+ Deconstruct a properly nested with 3 elements.
+
+
+
+
+ Deconstruct a properly nested with 4 elements.
+
+
+
+
+ Deconstruct a properly nested with 5 elements.
+
+
+
+
+ Deconstruct a properly nested with 6 elements.
+
+
+
+
+ Deconstruct a properly nested with 7 elements.
+
+
+
+
+ Deconstruct a properly nested with 8 elements.
+
+
+
+
+ Deconstruct a properly nested with 9 elements.
+
+
+
+
+ Deconstruct a properly nested with 10 elements.
+
+
+
+
+ Deconstruct a properly nested with 11 elements.
+
+
+
+
+ Deconstruct a properly nested with 12 elements.
+
+
+
+
+ Deconstruct a properly nested with 13 elements.
+
+
+
+
+ Deconstruct a properly nested with 14 elements.
+
+
+
+
+ Deconstruct a properly nested with 15 elements.
+
+
+
+
+ Deconstruct a properly nested with 16 elements.
+
+
+
+
+ Deconstruct a properly nested with 17 elements.
+
+
+
+
+ Deconstruct a properly nested with 18 elements.
+
+
+
+
+ Deconstruct a properly nested with 19 elements.
+
+
+
+
+ Deconstruct a properly nested with 20 elements.
+
+
+
+
+ Deconstruct a properly nested with 21 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 1 element.
+
+
+
+
+ Make a properly nested from a properly nested with 2 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 3 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 4 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 5 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 6 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 7 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 8 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 9 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 10 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 11 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 12 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 13 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 14 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 15 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 16 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 17 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 18 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 19 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 20 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 21 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 1 element.
+
+
+
+
+ Make a properly nested from a properly nested with 2 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 3 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 4 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 5 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 6 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 7 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 8 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 9 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 10 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 11 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 12 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 13 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 14 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 15 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 16 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 17 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 18 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 19 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 20 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 21 elements.
+
+
+
+
+ Helper so we can call some tuple methods recursively without knowing the underlying types.
+
+
+
+
+ The ValueTuple types (from arity 0 to 8) comprise the runtime implementation that underlies tuples in C# and struct tuples in F#.
+ Aside from created via language syntax, they are most easily created via the ValueTuple.Create factory methods.
+ The System.ValueTuple types differ from the System.Tuple types in that:
+ - they are structs rather than classes,
+ - they are mutable rather than readonly, and
+ - their members (such as Item1, Item2, etc) are fields rather than properties.
+
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if is a .
+
+
+ Returns a value indicating whether this instance is equal to a specified value.
+ An instance to compare to this instance.
+ true if has the same value as this instance; otherwise, false.
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+ Returns the hash code for this instance.
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form ().
+
+
+
+ Creates a new struct 0-tuple.
+ A 0-tuple.
+
+
+ Creates a new struct 1-tuple, or singleton.
+ The type of the first component of the tuple.
+ The value of the first component of the tuple.
+ A 1-tuple (singleton) whose value is (item1).
+
+
+ Creates a new struct 2-tuple, or pair.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ A 2-tuple (pair) whose value is (item1, item2).
+
+
+ Creates a new struct 3-tuple, or triple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ A 3-tuple (triple) whose value is (item1, item2, item3).
+
+
+ Creates a new struct 4-tuple, or quadruple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ A 4-tuple (quadruple) whose value is (item1, item2, item3, item4).
+
+
+ Creates a new struct 5-tuple, or quintuple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The type of the fifth component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ The value of the fifth component of the tuple.
+ A 5-tuple (quintuple) whose value is (item1, item2, item3, item4, item5).
+
+
+ Creates a new struct 6-tuple, or sextuple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The type of the fifth component of the tuple.
+ The type of the sixth component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ The value of the fifth component of the tuple.
+ The value of the sixth component of the tuple.
+ A 6-tuple (sextuple) whose value is (item1, item2, item3, item4, item5, item6).
+
+
+ Creates a new struct 7-tuple, or septuple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The type of the fifth component of the tuple.
+ The type of the sixth component of the tuple.
+ The type of the seventh component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ The value of the fifth component of the tuple.
+ The value of the sixth component of the tuple.
+ The value of the seventh component of the tuple.
+ A 7-tuple (septuple) whose value is (item1, item2, item3, item4, item5, item6, item7).
+
+
+ Creates a new struct 8-tuple, or octuple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The type of the fifth component of the tuple.
+ The type of the sixth component of the tuple.
+ The type of the seventh component of the tuple.
+ The type of the eighth component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ The value of the fifth component of the tuple.
+ The value of the sixth component of the tuple.
+ The value of the seventh component of the tuple.
+ The value of the eighth component of the tuple.
+ An 8-tuple (octuple) whose value is (item1, item2, item3, item4, item5, item6, item7, item8).
+
+
+ Represents a 1-tuple, or singleton, as a value type.
+ The type of the tuple's only component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its field
+ is equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1),
+ where Item1 represents the value of . If the field is ,
+ it is represented as .
+
+
+
+
+ Represents a 2-tuple, or pair, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's first component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object based on a specified comparison method.
+
+ The object to compare with this instance.
+ An object that defines the method to use to evaluate whether the two objects are equal.
+ if the current instance is equal to the specified object; otherwise, .
+
+
+ This member is an explicit interface member implementation. It can be used only when the
+ instance is cast to an interface.
+
+ The implementation is called only if other is not ,
+ and if it can be successfully cast (in C#) or converted (in Visual Basic) to a
+ whose components are of the same types as those of the current instance. The IStructuralEquatable.Equals(Object, IEqualityComparer) method
+ first passes the values of the objects to be compared to the
+ implementation. If this method call returns , the method is
+ called again and passed the values of the two instances.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2),
+ where Item1 and Item2 represent the values of the
+ and fields. If either field value is ,
+ it is represented as .
+
+
+
+
+ Represents a 3-tuple, or triple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents a 4-tuple, or quadruple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents a 5-tuple, or quintuple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+ The type of the tuple's fifth component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ The current instance's fifth component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+ The value of the tuple's fifth component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4, Item5).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents a 6-tuple, or sixtuple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+ The type of the tuple's fifth component.
+ The type of the tuple's sixth component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ The current instance's fifth component.
+
+
+
+
+ The current instance's sixth component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+ The value of the tuple's fifth component.
+ The value of the tuple's sixth component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4, Item5, Item6).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents a 7-tuple, or sentuple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+ The type of the tuple's fifth component.
+ The type of the tuple's sixth component.
+ The type of the tuple's seventh component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ The current instance's fifth component.
+
+
+
+
+ The current instance's sixth component.
+
+
+
+
+ The current instance's seventh component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+ The value of the tuple's fifth component.
+ The value of the tuple's sixth component.
+ The value of the tuple's seventh component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4, Item5, Item6, Item7).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents an 8-tuple, or octuple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+ The type of the tuple's fifth component.
+ The type of the tuple's sixth component.
+ The type of the tuple's seventh component.
+ The type of the tuple's eighth component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ The current instance's fifth component.
+
+
+
+
+ The current instance's sixth component.
+
+
+
+
+ The current instance's seventh component.
+
+
+
+
+ The current instance's eighth component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+ The value of the tuple's fifth component.
+ The value of the tuple's sixth component.
+ The value of the tuple's seventh component.
+ The value of the tuple's eight component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4, Item5, Item6, Item7, Rest).
+ If any field value is , it is represented as .
+
+
+
+
diff --git a/packages/System.ValueTuple.4.3.0/lib/netstandard1.0/System.ValueTuple.dll b/packages/System.ValueTuple.4.3.0/lib/netstandard1.0/System.ValueTuple.dll
new file mode 100644
index 00000000..78a18514
Binary files /dev/null and b/packages/System.ValueTuple.4.3.0/lib/netstandard1.0/System.ValueTuple.dll differ
diff --git a/packages/System.ValueTuple.4.3.0/lib/portable-net40+sl4+win8+wp8/.xml b/packages/System.ValueTuple.4.3.0/lib/portable-net40+sl4+win8+wp8/.xml
new file mode 100644
index 00000000..270d6efb
--- /dev/null
+++ b/packages/System.ValueTuple.4.3.0/lib/portable-net40+sl4+win8+wp8/.xml
@@ -0,0 +1,1299 @@
+
+
+
+ System.ValueTuple
+
+
+
+
+ Indicates that the use of on a member is meant to be treated as a tuple with element names.
+
+
+
+
+ Initializes a new instance of the class.
+
+
+ Specifies, in a pre-order depth-first traversal of a type's
+ construction, which occurrences are
+ meant to carry element names.
+
+
+ This constructor is meant to be used on types that contain an
+ instantiation of that contains
+ element names. For instance, if C is a generic type with
+ two type parameters, then a use of the constructed type C{, might be intended to
+ treat the first type argument as a tuple with element names and the
+ second as a tuple without element names. In which case, the
+ appropriate attribute specification should use a
+ transformNames value of { "name1", "name2", null, null,
+ null }.
+
+
+
+
+ Specifies, in a pre-order depth-first traversal of a type's
+ construction, which elements are
+ meant to carry element names.
+
+
+
+
+ Provides extension methods for instances to interop with C# tuples features (deconstruction syntax, converting from and to ).
+
+
+
+
+ Deconstruct a properly nested with 1 elements.
+
+
+
+
+ Deconstruct a properly nested with 2 elements.
+
+
+
+
+ Deconstruct a properly nested with 3 elements.
+
+
+
+
+ Deconstruct a properly nested with 4 elements.
+
+
+
+
+ Deconstruct a properly nested with 5 elements.
+
+
+
+
+ Deconstruct a properly nested with 6 elements.
+
+
+
+
+ Deconstruct a properly nested with 7 elements.
+
+
+
+
+ Deconstruct a properly nested with 8 elements.
+
+
+
+
+ Deconstruct a properly nested with 9 elements.
+
+
+
+
+ Deconstruct a properly nested with 10 elements.
+
+
+
+
+ Deconstruct a properly nested with 11 elements.
+
+
+
+
+ Deconstruct a properly nested with 12 elements.
+
+
+
+
+ Deconstruct a properly nested with 13 elements.
+
+
+
+
+ Deconstruct a properly nested with 14 elements.
+
+
+
+
+ Deconstruct a properly nested with 15 elements.
+
+
+
+
+ Deconstruct a properly nested with 16 elements.
+
+
+
+
+ Deconstruct a properly nested with 17 elements.
+
+
+
+
+ Deconstruct a properly nested with 18 elements.
+
+
+
+
+ Deconstruct a properly nested with 19 elements.
+
+
+
+
+ Deconstruct a properly nested with 20 elements.
+
+
+
+
+ Deconstruct a properly nested with 21 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 1 element.
+
+
+
+
+ Make a properly nested from a properly nested with 2 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 3 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 4 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 5 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 6 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 7 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 8 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 9 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 10 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 11 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 12 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 13 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 14 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 15 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 16 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 17 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 18 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 19 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 20 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 21 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 1 element.
+
+
+
+
+ Make a properly nested from a properly nested with 2 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 3 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 4 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 5 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 6 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 7 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 8 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 9 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 10 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 11 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 12 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 13 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 14 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 15 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 16 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 17 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 18 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 19 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 20 elements.
+
+
+
+
+ Make a properly nested from a properly nested with 21 elements.
+
+
+
+
+ Helper so we can call some tuple methods recursively without knowing the underlying types.
+
+
+
+
+ The ValueTuple types (from arity 0 to 8) comprise the runtime implementation that underlies tuples in C# and struct tuples in F#.
+ Aside from created via language syntax, they are most easily created via the ValueTuple.Create factory methods.
+ The System.ValueTuple types differ from the System.Tuple types in that:
+ - they are structs rather than classes,
+ - they are mutable rather than readonly, and
+ - their members (such as Item1, Item2, etc) are fields rather than properties.
+
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if is a .
+
+
+ Returns a value indicating whether this instance is equal to a specified value.
+ An instance to compare to this instance.
+ true if has the same value as this instance; otherwise, false.
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+ Returns the hash code for this instance.
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form ().
+
+
+
+ Creates a new struct 0-tuple.
+ A 0-tuple.
+
+
+ Creates a new struct 1-tuple, or singleton.
+ The type of the first component of the tuple.
+ The value of the first component of the tuple.
+ A 1-tuple (singleton) whose value is (item1).
+
+
+ Creates a new struct 2-tuple, or pair.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ A 2-tuple (pair) whose value is (item1, item2).
+
+
+ Creates a new struct 3-tuple, or triple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ A 3-tuple (triple) whose value is (item1, item2, item3).
+
+
+ Creates a new struct 4-tuple, or quadruple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ A 4-tuple (quadruple) whose value is (item1, item2, item3, item4).
+
+
+ Creates a new struct 5-tuple, or quintuple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The type of the fifth component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ The value of the fifth component of the tuple.
+ A 5-tuple (quintuple) whose value is (item1, item2, item3, item4, item5).
+
+
+ Creates a new struct 6-tuple, or sextuple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The type of the fifth component of the tuple.
+ The type of the sixth component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ The value of the fifth component of the tuple.
+ The value of the sixth component of the tuple.
+ A 6-tuple (sextuple) whose value is (item1, item2, item3, item4, item5, item6).
+
+
+ Creates a new struct 7-tuple, or septuple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The type of the fifth component of the tuple.
+ The type of the sixth component of the tuple.
+ The type of the seventh component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ The value of the fifth component of the tuple.
+ The value of the sixth component of the tuple.
+ The value of the seventh component of the tuple.
+ A 7-tuple (septuple) whose value is (item1, item2, item3, item4, item5, item6, item7).
+
+
+ Creates a new struct 8-tuple, or octuple.
+ The type of the first component of the tuple.
+ The type of the second component of the tuple.
+ The type of the third component of the tuple.
+ The type of the fourth component of the tuple.
+ The type of the fifth component of the tuple.
+ The type of the sixth component of the tuple.
+ The type of the seventh component of the tuple.
+ The type of the eighth component of the tuple.
+ The value of the first component of the tuple.
+ The value of the second component of the tuple.
+ The value of the third component of the tuple.
+ The value of the fourth component of the tuple.
+ The value of the fifth component of the tuple.
+ The value of the sixth component of the tuple.
+ The value of the seventh component of the tuple.
+ The value of the eighth component of the tuple.
+ An 8-tuple (octuple) whose value is (item1, item2, item3, item4, item5, item6, item7, item8).
+
+
+ Represents a 1-tuple, or singleton, as a value type.
+ The type of the tuple's only component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its field
+ is equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1),
+ where Item1 represents the value of . If the field is ,
+ it is represented as .
+
+
+
+
+ Represents a 2-tuple, or pair, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's first component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object based on a specified comparison method.
+
+ The object to compare with this instance.
+ An object that defines the method to use to evaluate whether the two objects are equal.
+ if the current instance is equal to the specified object; otherwise, .
+
+
+ This member is an explicit interface member implementation. It can be used only when the
+ instance is cast to an interface.
+
+ The implementation is called only if other is not ,
+ and if it can be successfully cast (in C#) or converted (in Visual Basic) to a
+ whose components are of the same types as those of the current instance. The IStructuralEquatable.Equals(Object, IEqualityComparer) method
+ first passes the values of the objects to be compared to the
+ implementation. If this method call returns , the method is
+ called again and passed the values of the two instances.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2),
+ where Item1 and Item2 represent the values of the
+ and fields. If either field value is ,
+ it is represented as .
+
+
+
+
+ Represents a 3-tuple, or triple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents a 4-tuple, or quadruple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents a 5-tuple, or quintuple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+ The type of the tuple's fifth component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ The current instance's fifth component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+ The value of the tuple's fifth component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4, Item5).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents a 6-tuple, or sixtuple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+ The type of the tuple's fifth component.
+ The type of the tuple's sixth component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ The current instance's fifth component.
+
+
+
+
+ The current instance's sixth component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+ The value of the tuple's fifth component.
+ The value of the tuple's sixth component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4, Item5, Item6).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents a 7-tuple, or sentuple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+ The type of the tuple's fifth component.
+ The type of the tuple's sixth component.
+ The type of the tuple's seventh component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ The current instance's fifth component.
+
+
+
+
+ The current instance's sixth component.
+
+
+
+
+ The current instance's seventh component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+ The value of the tuple's fifth component.
+ The value of the tuple's sixth component.
+ The value of the tuple's seventh component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4, Item5, Item6, Item7).
+ If any field value is , it is represented as .
+
+
+
+
+ Represents an 8-tuple, or octuple, as a value type.
+
+ The type of the tuple's first component.
+ The type of the tuple's second component.
+ The type of the tuple's third component.
+ The type of the tuple's fourth component.
+ The type of the tuple's fifth component.
+ The type of the tuple's sixth component.
+ The type of the tuple's seventh component.
+ The type of the tuple's eighth component.
+
+
+
+ The current instance's first component.
+
+
+
+
+ The current instance's second component.
+
+
+
+
+ The current instance's third component.
+
+
+
+
+ The current instance's fourth component.
+
+
+
+
+ The current instance's fifth component.
+
+
+
+
+ The current instance's sixth component.
+
+
+
+
+ The current instance's seventh component.
+
+
+
+
+ The current instance's eighth component.
+
+
+
+
+ Initializes a new instance of the value type.
+
+ The value of the tuple's first component.
+ The value of the tuple's second component.
+ The value of the tuple's third component.
+ The value of the tuple's fourth component.
+ The value of the tuple's fifth component.
+ The value of the tuple's sixth component.
+ The value of the tuple's seventh component.
+ The value of the tuple's eight component.
+
+
+
+ Returns a value that indicates whether the current instance is equal to a specified object.
+
+ The object to compare with this instance.
+ if the current instance is equal to the specified object; otherwise, .
+
+ The parameter is considered to be equal to the current instance under the following conditions:
+
+ - It is a value type.
+ - Its components are of the same types as those of the current instance.
+ - Its components are equal to those of the current instance. Equality is determined by the default object equality comparer for each component.
+
+
+
+
+
+ Returns a value that indicates whether the current
+ instance is equal to a specified .
+
+ The tuple to compare with this instance.
+ if the current instance is equal to the specified tuple; otherwise, .
+
+ The parameter is considered to be equal to the current instance if each of its fields
+ are equal to that of the current instance, using the default comparer for that field's type.
+
+
+
+ Compares this instance to a specified instance and returns an indication of their relative values.
+ An instance to compare.
+
+ A signed number indicating the relative values of this instance and .
+ Returns less than zero if this instance is less than , zero if this
+ instance is equal to , and greater than zero if this instance is greater
+ than .
+
+
+
+
+ Returns the hash code for the current instance.
+
+ A 32-bit signed integer hash code.
+
+
+
+ Returns a string that represents the value of this instance.
+
+ The string representation of this instance.
+
+ The string returned by this method takes the form (Item1, Item2, Item3, Item4, Item5, Item6, Item7, Rest).
+ If any field value is , it is represented as .
+
+
+
+
diff --git a/packages/System.ValueTuple.4.3.0/lib/portable-net40+sl4+win8+wp8/System.ValueTuple.dll b/packages/System.ValueTuple.4.3.0/lib/portable-net40+sl4+win8+wp8/System.ValueTuple.dll
new file mode 100644
index 00000000..e64e5d41
Binary files /dev/null and b/packages/System.ValueTuple.4.3.0/lib/portable-net40+sl4+win8+wp8/System.ValueTuple.dll differ