FormMain.cs 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. using System.Data;
  2. using System.Diagnostics;
  3. using System.Linq;
  4. namespace ProcedureComparer
  5. {
  6. public partial class FormMain : Form
  7. {
  8. public delegate void ExecOtherServerDelegate(string serverName, string procedureContent);
  9. private const string SERVER1_NAME = "Server1";
  10. private const string SERVER2_NAME = "Server2";
  11. private const string INI_FOLDER_NAME = "ini_files";
  12. private readonly string PROCEDURE_LIST_INI_PATH = Path.Combine(Application.StartupPath, INI_FOLDER_NAME, "ProcedureList.ini");
  13. private readonly string CONFIG_INI_PATH = Path.Combine(Application.StartupPath, INI_FOLDER_NAME, "Config.ini");
  14. private string _WinMergePath = @"C:\Program Files\WinMerge\WinMergeU.exe";
  15. private DateTime? _LastTextChangeTime = null;
  16. public FormMain()
  17. {
  18. InitializeComponent();
  19. }
  20. private void FormMain_Load(object sender, EventArgs e)
  21. {
  22. InitializeServerInfo();
  23. }
  24. private void InitializeServerInfo()
  25. {
  26. server1.Initailize(SERVER1_NAME, CONFIG_INI_PATH);
  27. server1._ExecOtherServer = new ExecOtherServerDelegate(ExecOtherServer);
  28. server2.Initailize(SERVER2_NAME, CONFIG_INI_PATH);
  29. server2._ExecOtherServer = new ExecOtherServerDelegate(ExecOtherServer);
  30. }
  31. private void lv_ProcedureList_SelectedIndexChanged(object sender, EventArgs e)
  32. {
  33. if (lv_ProcedureList.SelectedItems.Count > 0)
  34. {
  35. string? procedureName = lv_ProcedureList.SelectedItems[0].SubItems[0].Text.Trim();
  36. string? type = lv_ProcedureList.SelectedItems[0].SubItems[1].Text.Trim();
  37. server1.Search(procedureName, type);
  38. server2.Search(procedureName, type);
  39. }
  40. }
  41. private void btn_OpenWinmerge_Click(object sender, EventArgs e)
  42. {
  43. string path1 = server1.SaveProcedure();
  44. string path2 = server2.SaveProcedure();
  45. if (path1 != string.Empty && path2 != string.Empty)
  46. {
  47. RunWinMerge(path1, path2);
  48. }
  49. }
  50. private void RunWinMerge(string path1, string path2)
  51. {
  52. try
  53. {
  54. // WinMerge 실행 경로 설정 (WinMerge가 설치된 디렉터리에 따라 수정)
  55. string winMergePath = new IniManager().GetIniValue(CONFIG_INI_PATH, "Config", "WinMergePath");
  56. if (winMergePath == string.Empty)
  57. {
  58. MessageBox.Show("WinMerge 프로그램 경로가 설정되지 않았습니다.");
  59. ShowWinMergePathSetting();
  60. return;
  61. }
  62. // 명령줄 인수 설정
  63. string arguments = $@"""{path1}"" ""{path2}""";
  64. // 프로세스 실행
  65. ProcessStartInfo startInfo = new ProcessStartInfo
  66. {
  67. FileName = winMergePath,
  68. Arguments = arguments,
  69. UseShellExecute = true
  70. };
  71. Process.Start(startInfo);
  72. }
  73. catch (Exception ex)
  74. {
  75. MessageBox.Show($"오류 발생: {ex.Message}", "오류", MessageBoxButtons.OK, MessageBoxIcon.Error);
  76. }
  77. }
  78. private void FormMain_FormClosing(object sender, FormClosingEventArgs e)
  79. {
  80. if (server1.isConnect)
  81. server1.Disconnect();
  82. if (server2.isConnect)
  83. server2.Disconnect();
  84. }
  85. private void ExecOtherServer(string serverName, string procedureContent)
  86. {
  87. Server otherServer = serverName == SERVER1_NAME ? server2 : server1;
  88. string otherServerName = serverName == SERVER1_NAME ? SERVER2_NAME : SERVER1_NAME;
  89. if (!otherServer.isConnect)
  90. {
  91. MessageBox.Show($"{otherServerName} > DB에 연결되지 않았습니다.");
  92. return;
  93. }
  94. otherServer.ExecuteProcedure(procedureContent);
  95. }
  96. private void btn_WinMergeSetting_Click(object sender, EventArgs e)
  97. {
  98. ShowWinMergePathSetting();
  99. }
  100. private void ShowWinMergePathSetting()
  101. {
  102. FormWinmergePathSetting formWinmergePathSetting = new FormWinmergePathSetting(CONFIG_INI_PATH);
  103. formWinmergePathSetting.ShowDialog();
  104. }
  105. private void tb_ProcedureName_TextChanged(object sender, EventArgs e)
  106. {
  107. _LastTextChangeTime = DateTime.Now;
  108. tmr_SearchProcedureName.Enabled = true;
  109. }
  110. private List<Tuple<string, string>>? MergeTables(DataTable? table1, DataTable? table2)
  111. {
  112. if (table1 == null && table2 == null)
  113. return null;
  114. else if (table1 == null || table2 == null)
  115. return DataTableToListString(table1 ?? table2);
  116. else
  117. {
  118. List<Tuple<string, string>> procedureNameList = DataTableToListString(table1);
  119. foreach (DataRow dataRow in table2.Rows)
  120. {
  121. string procedureName = dataRow[0].ToString();
  122. string type = dataRow[1].ToString();
  123. Tuple<string, string> procedure = new Tuple<string, string>(procedureName, type);
  124. if (!procedureNameList.Contains(procedure))
  125. procedureNameList.Add(procedure);
  126. }
  127. return procedureNameList.OrderBy(procedureName => procedureName).ToList();
  128. }
  129. }
  130. private List<Tuple<string, string>> DataTableToListString(DataTable dataTable)
  131. {
  132. List<Tuple<string, string>> list = new List<Tuple<string, string>>();
  133. foreach (DataRow row in dataTable.Rows)
  134. {
  135. list.Add(new Tuple<string, string>(row[0].ToString(), row[1].ToString()));
  136. }
  137. return list;
  138. }
  139. private void SetListViewItems(List<Tuple<string, string>>? itemList)
  140. {
  141. lv_ProcedureList.Items.Clear();
  142. if (itemList != null)
  143. {
  144. foreach (Tuple<string, string> item in itemList)
  145. {
  146. if (item.Item1.Trim() != string.Empty)
  147. {
  148. ListViewItem listViewItem = new ListViewItem(item.Item1);
  149. listViewItem.SubItems.Add(item.Item2);
  150. lv_ProcedureList.Items.Add(listViewItem);
  151. }
  152. }
  153. }
  154. }
  155. private void FormMain_KeyUp(object sender, KeyEventArgs e)
  156. {
  157. switch (e.KeyCode)
  158. {
  159. case Keys.F3:
  160. if (!server1.isConnect)
  161. server1.btn_Connect_Click(null, null);
  162. break;
  163. case Keys.F4:
  164. if (!server2.isConnect)
  165. server2.btn_Connect_Click(null, null);
  166. break;
  167. case Keys.F5:
  168. btn_OpenWinmerge_Click(null, null);
  169. break;
  170. case Keys.F6:
  171. tb_ProcedureName.Focus();
  172. tb_ProcedureName.SelectAll();
  173. break;
  174. }
  175. }
  176. private void tb_ProcedureName_KeyUp(object sender, KeyEventArgs e)
  177. {
  178. if (e.KeyCode == Keys.Enter)
  179. {
  180. lv_ProcedureList.Focus();
  181. if (lv_ProcedureList.Items.Count > 0)
  182. lv_ProcedureList.Items[0].Selected = true;
  183. }
  184. }
  185. private void tmr_SearchProcedureName_Tick(object sender, EventArgs e)
  186. {
  187. if (_LastTextChangeTime != null)
  188. {
  189. if ((DateTime.Now - (DateTime)_LastTextChangeTime).TotalMilliseconds > 100)
  190. {
  191. tmr_SearchProcedureName.Enabled = false;
  192. string filterText = tb_ProcedureName.Text;
  193. DataTable? dataTable1 = server1.SearchProcedureNames(filterText);
  194. DataTable? dataTable2 = server2.SearchProcedureNames(filterText);
  195. SetListViewItems(MergeTables(dataTable1, dataTable2));
  196. }
  197. }
  198. }
  199. }
  200. }