Нет описания

Utils.cs 4.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using Microsoft.Win32;
  6. using System.IO.Ports;
  7. using System.Configuration;
  8. using System.Data.SqlClient;
  9. using System.Data.SqlServerCe;
  10. namespace WpfApplication19
  11. {
  12. class Utils
  13. {
  14. static public Dictionary<string, string> BuildPortNameHash(string[] portsToMap)
  15. {
  16. Dictionary<string, string> oReturnTable = new Dictionary<string, string>();
  17. MineRegistryForPortName("SYSTEM\\CurrentControlSet\\Enum", oReturnTable, portsToMap);
  18. return oReturnTable;
  19. }
  20. static void MineRegistryForPortName(string startKeyPath, Dictionary<string, string> targetMap,
  21. string[] portsToMap)
  22. {
  23. if (targetMap.Count >= portsToMap.Length)
  24. return;
  25. using (RegistryKey currentKey = Registry.LocalMachine)
  26. {
  27. try
  28. {
  29. using (RegistryKey currentSubKey = currentKey.OpenSubKey(startKeyPath))
  30. {
  31. string[] currentSubkeys = currentSubKey.GetSubKeyNames();
  32. if (currentSubkeys.Contains("Device Parameters") &&
  33. startKeyPath != "SYSTEM\\CurrentControlSet\\Enum")
  34. {
  35. object portName = Registry.GetValue("HKEY_LOCAL_MACHINE\\" +
  36. startKeyPath + "\\Device Parameters", "PortName", null);
  37. if (portName == null ||
  38. portsToMap.Contains(portName.ToString()) == false)
  39. return;
  40. object friendlyPortName = Registry.GetValue("HKEY_LOCAL_MACHINE\\" +
  41. startKeyPath, "FriendlyName", null);
  42. string friendlyName = "N/A";
  43. if (friendlyPortName != null)
  44. friendlyName = friendlyPortName.ToString();
  45. if (friendlyName.Contains(portName.ToString()) == false)
  46. friendlyName = string.Format("{0} ({1})", friendlyName, portName);
  47. targetMap[portName.ToString()] = friendlyName;
  48. }
  49. else
  50. {
  51. foreach (string strSubKey in currentSubkeys)
  52. MineRegistryForPortName(startKeyPath + "\\" + strSubKey, targetMap, portsToMap);
  53. }
  54. }
  55. }
  56. catch (Exception)
  57. {
  58. //Console.WriteLine("Error accessing key '{0}'.. Skipping..", startKeyPath);
  59. }
  60. }
  61. }
  62. public static void UpdateSetting(string key, string value)
  63. {
  64. Configuration oConfig = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
  65. if (oConfig.AppSettings.Settings[key] == null)
  66. {
  67. oConfig.AppSettings.Settings.Add(key, value);
  68. }
  69. else
  70. {
  71. oConfig.AppSettings.Settings[key].Value = value;
  72. }
  73. oConfig.Save(ConfigurationSaveMode.Modified);
  74. ConfigurationManager.RefreshSection("appSettings");
  75. }
  76. public static string getSetting(string key)
  77. {
  78. Configuration oConfig = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
  79. return oConfig.AppSettings.Settings[key].Value;
  80. }
  81. public static SqlConnection createSqlConnection(string configType)
  82. {
  83. SqlConnection sqlConn = new SqlConnection();
  84. string cs = Utils.getSetting(configType);
  85. sqlConn.ConnectionString = cs;
  86. sqlConn.Open();
  87. return sqlConn;
  88. }
  89. public static SqlCeConnection createSqlCeConnection(string configType)
  90. {
  91. SqlCeConnection sqlConn = new SqlCeConnection();
  92. string cs = Utils.getSetting(configType);
  93. sqlConn.ConnectionString = cs;
  94. sqlConn.Open();
  95. return sqlConn;
  96. }
  97. public static SqlDataReader Query(SqlConnection connection, string sql)
  98. {
  99. SqlCommand catCMD = connection.CreateCommand();
  100. catCMD.CommandText = sql;
  101. Console.WriteLine(sql);
  102. SqlDataReader reader = catCMD.ExecuteReader();
  103. return reader;
  104. }
  105. public static SqlCeDataReader Query(SqlCeConnection connection, string sql)
  106. {
  107. SqlCeCommand catCMD = connection.CreateCommand();
  108. catCMD.CommandText = sql;
  109. Console.WriteLine(sql);
  110. SqlCeDataReader reader = catCMD.ExecuteReader();
  111. return reader;
  112. }
  113. }
  114. }