// ******************************************************************************// // RAYTHEON PROPRIETARY: THIS DOCUMENT CONTAINS DATA OR INFORMATION // PROPRIETARY TO RAYTHEON COMPANY AND IS RESTRICTED TO USE ONLY BY PERSONS // AUTHORIZED BY RAYTHEON COMPANY IN WRITING TO USE IT. DISCLOSURE TO // UNAUTHORIZED PERSONS WOULD LIKELY CAUSE SUBSTANTIAL COMPETITIVE HARM TO // RAYTHEON COMPANY''S BUSINESS POSITION. NEITHER SAID DOCUMENT NOR ITS // CONTENTS SHALL BE FURNISHED OR DISCLOSED TO OR COPIED OR USED BY PERSONS // OUTSIDE RAYTHEON COMPANY WITHOUT THE EXPRESS WRITTEN APPROVAL OF RAYTHEON // COMPANY. // // THIS PROPRIETARY NOTICE IS NOT APPLICABLE IF DELIVERED TO THE U.S. GOVERNMENT // // UNPUBLISHED WORK - COPYRIGHT RAYTHEON COMPANY. // // WARNING: THIS DOCUMENT CONTAINS TECHNICAL DATA AND / OR TECHNOLOGY WHOSE // EXPORT OR DISCLOSURE TO NON-U.S. PERSONS, WHEREVER LOCATED, IS RESTRICTED // BY THE INTERNATIONAL TRAFFIC IN ARMS REGULATIONS (ITAR) (22 C.F.R. SECTION // 120-130) OR THE EXPORT ADMINISTRATION REGULATIONS (EAR) (15 C.F.R. SECTION // 730-774). THIS DOCUMENT CANNOT BE EXPORTED (E.G., PROVIDED TO A SUPPLIER // OUTSIDE OF THE UNITED STATES) OR DISCLOSED TO A NON-U.S. PERSON, WHEREVER // LOCATED, UNTIL A FINAL JURISDICTION AND CLASSIFICATION DETERMINATION HAS // BEEN COMPLETED AND APPROVED BY RAYTHEON, AND ANY REQUIRED U.S. GOVERNMENT // APPROVALS HAVE BEEN OBTAINED. VIOLATIONS ARE SUBJECT TO SEVERE CRIMINAL // PENALTIES. // // DOD 5220.22-M, INDUSTRIAL SECURITY MANUAL, CHAPTER 5, SECTION 1 THROUGH 9 : // FOR CLASSIFIED DOCUMENTS FOLLOW THE PROCEDURES IN OR DOD 5200.1-R, // INFORMATION SECURITY PROGRAM, CHAPTER 6. FOR UNCLASSIFIED, LIMITED DOCUMENTS // DESTROY BY ANY METHOD THAT WILL PREVENT DISCLOSURE OF CONTENTS OR // RECONSTRUCTION OF THE DOCUMENT. // ****************************************************************************// using System.Collections.Generic; namespace Raytheon.Common { /// /// supported file types /// public enum ConfigurationFileType { INI, XML, TOML, JSON, YAML, OTHER } /// /// updated version of IConfiguration interface /// allows reading and writing generic types as well as lists /// public interface IConfigurationFile { /// /// reads a single generic type value from the file section /// if value or section does not exist, will create one and will add the default value /// /// /// /// /// /// T ReadValue(string section, string key, T defValue = default); /// /// reads a single generic type value from the file section /// if value doesn't exist, throw exception /// /// /// /// string ReadValue(string section, string key); /// /// reads a list of generic type values from the file section /// if list or section does not exist, will create one and will populate with the default list /// /// /// /// /// /// List ReadList(string section, string key, IList defList = null); /// /// reads all available keys from the given section of configuration file /// /// /// List ReadAllKeys(string section); /// /// reads all available sections from configuration file /// /// List ReadAllSections(); /// /// writes a single value of a generic type /// /// /// /// /// void WriteValue(string section, string key, T lineToWrite); /// /// writes a list of generic values /// /// /// /// /// void WriteList(string section, string key, IList listToWrite); /// /// checks if the value exists in the given section and given key /// /// /// /// bool ValueExists(string section, string key); /// /// configuration file name /// string FileName { get; } /// /// configuration file type /// ConfigurationFileType ConfigurationFileType { get; } } }