Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

398 lines
12 KiB

  1. /****************************************************************************\
  2. OEMINFO.C / OPK Wizard (OPKWIZ.EXE)
  3. Microsoft Confidential
  4. Copyright (c) Microsoft Corporation 1998
  5. All rights reserved
  6. Source file for the OPK Wizard that contains the external and internal
  7. functions used by the "OEM info" wizard page.
  8. 5/99 - Jason Cohen (JCOHEN)
  9. Updated this old source file for the OPK Wizard as part of the
  10. Millennium rewrite.
  11. 09/2000 - Stephen Lodwick (STELO)
  12. Ported OPK Wizard to Whistler
  13. \****************************************************************************/
  14. //
  15. // Include File(s):
  16. //
  17. #include "pch.h"
  18. #include "wizard.h"
  19. #include "resource.h"
  20. //
  21. // Internal Defined Value(s):
  22. //
  23. #define INI_SEC_SUPPORT _T("Support Information")
  24. #define INI_SEC_NAUGHTY _T("IllegalWords")
  25. #define INI_SEC_USERDATA _T("UserData")
  26. #define INI_KEY_MODELNAME _T("Model")
  27. #define INI_KEY_SUPLINE INI_KEY_FILELINE
  28. //
  29. // Internal Function Prototype(s):
  30. //
  31. static BOOL OnInit(HWND, HWND, LPARAM);
  32. static BOOL ValidData(HWND);
  33. static void SaveData(HWND);
  34. LONG CALLBACK SupportEditWndProc(HWND, UINT, WPARAM, LPARAM);
  35. //
  36. // External Function(s):
  37. //
  38. LRESULT CALLBACK OemInfoDlgProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
  39. {
  40. switch (uMsg)
  41. {
  42. HANDLE_MSG(hwnd, WM_INITDIALOG, OnInit);
  43. case WM_NOTIFY:
  44. switch ( ((NMHDR FAR *) lParam)->code )
  45. {
  46. case PSN_KILLACTIVE:
  47. case PSN_RESET:
  48. case PSN_WIZBACK:
  49. case PSN_WIZFINISH:
  50. break;
  51. case PSN_WIZNEXT:
  52. if ( ValidData(hwnd) )
  53. {
  54. SaveData(hwnd);
  55. // If we are currently in the wizard, press the finish button
  56. //
  57. if ( GET_FLAG(OPK_ACTIVEWIZ) )
  58. WIZ_PRESS(hwnd, PSBTN_FINISH);
  59. }
  60. else
  61. WIZ_FAIL(hwnd);
  62. break;
  63. case PSN_QUERYCANCEL:
  64. WIZ_CANCEL(hwnd);
  65. break;
  66. case PSN_HELP:
  67. WIZ_HELP();
  68. break;
  69. case PSN_SETACTIVE:
  70. g_App.dwCurrentHelp = IDH_OEMINFO;
  71. WIZ_BUTTONS(hwnd, GET_FLAG(OPK_OEM) ? (PSWIZB_BACK | PSWIZB_NEXT) : PSWIZB_NEXT);
  72. // Press next if the user is in auto mode
  73. //
  74. WIZ_NEXTONAUTO(hwnd, PSBTN_NEXT);
  75. // We should continue on to maint. wizard if in maintenance mode
  76. //
  77. //if ( GET_FLAG(OPK_MAINTMODE) )
  78. // WIZ_PRESS(hwnd, PSBTN_NEXT);
  79. break;
  80. }
  81. break;
  82. default:
  83. return FALSE;
  84. }
  85. return TRUE;
  86. }
  87. //
  88. // Internal Function(s):
  89. //
  90. static BOOL OnInit(HWND hwnd, HWND hwndFocus, LPARAM lParam)
  91. {
  92. HWND hwndEdit = GetDlgItem(hwnd, IDC_INFO_SUPPORT);
  93. TCHAR szBuf[MAX_URL],
  94. szKeyBuf[32];
  95. INT uIndex = 1;
  96. BOOL bNotDone;
  97. HRESULT hrPrintf;
  98. //
  99. // Get stuff from the oeminfo.ini/opkwiz.inf file.
  100. //
  101. // OEM name.
  102. //
  103. szBuf[0] = NULLCHR;
  104. GetPrivateProfileString(INI_SEC_GENERAL, INI_KEY_MANUFACT, NULLSTR, szBuf, MAX_INFOLEN, GET_FLAG(OPK_BATCHMODE) ? g_App.szOpkWizIniFile : g_App.szOemInfoIniFile);
  105. SetWindowText(GetDlgItem(hwnd, IDC_INFO_OEM), szBuf);
  106. SendDlgItemMessage(hwnd, IDC_INFO_OEM, EM_LIMITTEXT, MAX_INFOLEN - 1, 0L);
  107. // Model name.
  108. //
  109. szBuf[0] = NULLCHR;
  110. GetPrivateProfileString(INI_SEC_GENERAL, INI_KEY_MODELNAME, NULLSTR, szBuf, MAX_INFOLEN, GET_FLAG(OPK_BATCHMODE) ? g_App.szOpkWizIniFile : g_App.szOemInfoIniFile);
  111. SetWindowText(GetDlgItem(hwnd, IDC_INFO_MODEL), szBuf);
  112. SendDlgItemMessage(hwnd, IDC_INFO_MODEL, EM_LIMITTEXT, MAX_INFOLEN - 1, 0L);
  113. // Support info.
  114. //
  115. // This exists in the section as:
  116. //
  117. // Line1="df"
  118. // Line2="dfvkl"
  119. //
  120. // Note we read lines in order (Line1, Line2...) and stop as soon
  121. // as we see a gap. This means we ingnore the rest of the info if they
  122. // have skipped a line (blanks are ok, i mean a line not existing).
  123. //
  124. do
  125. {
  126. // Get the line from the ini file.
  127. //
  128. hrPrintf=StringCchPrintf(szKeyBuf, AS(szKeyBuf), INI_KEY_SUPLINE, uIndex++);
  129. szBuf[0] = NULLCHR;
  130. GetPrivateProfileString(INI_SEC_SUPPORT, szKeyBuf, INI_VAL_DUMMY, szBuf, STRSIZE(szBuf), GET_FLAG(OPK_BATCHMODE) ? g_App.szOpkWizIniFile : g_App.szOemInfoIniFile);
  131. // Make sure the line existed in the ini file.
  132. //
  133. if ( bNotDone = (lstrcmp(szBuf, INI_VAL_DUMMY) != 0) )
  134. {
  135. // This is to fix a bug. We used to add a blank line everytime to
  136. // the support text when we ran in mantenance mode.
  137. //
  138. // If this isn't he first line we have added, add a CRLF first.
  139. //
  140. if ( uIndex > 2 )
  141. {
  142. SendMessage(hwndEdit, EM_SETSEL, (WPARAM) -1, 0L);
  143. SendMessage(hwndEdit, EM_REPLACESEL, FALSE, (LPARAM) STR_CRLF);
  144. }
  145. // Now tack this line we read in to the end of the edit control.
  146. //
  147. SendMessage(hwndEdit, EM_SETSEL, (WPARAM) -1, 0L);
  148. SendMessage(hwndEdit, EM_REPLACESEL, FALSE, (LPARAM) szBuf);
  149. }
  150. }
  151. while ( bNotDone );
  152. // Replace the wndproc for the edit box.
  153. //
  154. SupportEditWndProc(GetDlgItem(hwnd, IDC_INFO_SUPPORT), WM_SUBWNDPROC, 0, 0L);
  155. // Always return false to WM_INITDIALOG.
  156. //
  157. return FALSE;
  158. }
  159. static BOOL ValidData(HWND hwnd)
  160. {
  161. TCHAR szString[512] = NULLSTR;
  162. HINF hInf = NULL;
  163. INFCONTEXT InfContext;
  164. BOOL bOk = TRUE,
  165. bRet;
  166. HWND hwndOem = GetDlgItem(hwnd, IDC_INFO_OEM),
  167. hwndEdit = GetDlgItem(hwnd, IDC_INFO_SUPPORT);
  168. LPTSTR lpszText,
  169. lpBad;
  170. DWORD dwBuffer;
  171. // Check to make sure the OEM name is filled in.
  172. //
  173. if ( GetWindowTextLength(hwndOem) == 0 )
  174. {
  175. MsgBox(GetParent(hwnd), IDS_ERROEMNAME, IDS_APPNAME, MB_ERRORBOX);
  176. SetFocus(hwndOem);
  177. return FALSE;
  178. }
  179. // Check to make sure there is support information.
  180. //
  181. if ( GetWindowTextLength(hwndEdit) == 0 )
  182. {
  183. MsgBox(GetParent(hwnd), IDS_ERROEMSUPPORT, IDS_APPNAME, MB_ERRORBOX);
  184. SetFocus(hwndEdit);
  185. return FALSE;
  186. }
  187. //
  188. // Now make sure they don't use any naughty words.
  189. //
  190. // Get the text from the edit control.
  191. //
  192. dwBuffer = ((GetWindowTextLength(hwndEdit) + 1) * sizeof(TCHAR));
  193. if ( (lpszText = MALLOC(dwBuffer)) == NULL )
  194. return bOk;
  195. GetWindowText(hwndEdit, lpszText, dwBuffer);
  196. // Open the opkinput file
  197. //
  198. if ((hInf = SetupOpenInfFile(g_App.szOpkInputInfFile, NULL, INF_STYLE_OLDNT | INF_STYLE_WIN4, NULL)))
  199. {
  200. // Loop through all the naughty words and check for each.
  201. //
  202. for ( bRet = SetupFindFirstLine(hInf, INI_SEC_NAUGHTY, NULL, &InfContext);
  203. bRet && bOk;
  204. bRet = SetupFindNextLine(&InfContext, &InfContext) )
  205. {
  206. // Make sure we set the line back to nothing
  207. //
  208. szString[0] = NULLCHR;
  209. // Get the naughty word and compare to window text
  210. //
  211. if ( ( SetupGetStringField(&InfContext, 1, szString, AS(szString), NULL) ) &&
  212. ( lpBad = StrStrI(lpszText, szString) ) )
  213. {
  214. // We found a bad string.
  215. //
  216. MsgBox(GetParent(hwnd), IDS_ERR_NAUGHTY, IDS_ERR_NAUGHTY_TITLE, MB_ERRORBOX, szString);
  217. // Select the bad text in the edit control.
  218. //
  219. dwBuffer = (DWORD) (lpBad - lpszText);
  220. SetFocus(hwndEdit);
  221. PostMessage(hwndEdit, WM_SETSEL, (WPARAM) dwBuffer, (LPARAM) dwBuffer + lstrlen(szString));
  222. PostMessage(hwndEdit, EM_SCROLLCARET, 0, 0L);
  223. // Return false.
  224. //
  225. bOk = FALSE;
  226. }
  227. }
  228. SetupCloseInfFile(hInf);
  229. }
  230. // Free our edit text buffer.
  231. //
  232. FREE(lpszText);
  233. // Return our search result.
  234. //
  235. return bOk;
  236. }
  237. static void SaveData(HWND hwnd)
  238. {
  239. TCHAR szBuf[MAX_URL],
  240. szKeyBuf[32];
  241. UINT uCount,
  242. uIndex,
  243. uNumBytes;
  244. HRESULT hrPrintf;
  245. //
  246. // Save the stuff to the oeminfo.ini/opkwiz.ini file.
  247. //
  248. // OEM name.
  249. //
  250. GetDlgItemText(hwnd, IDC_INFO_OEM, szBuf, MAX_INFOLEN);
  251. WritePrivateProfileString(INI_SEC_GENERAL, INI_KEY_MANUFACT, szBuf,g_App.szOemInfoIniFile);
  252. WritePrivateProfileString(INI_SEC_GENERAL, INI_KEY_MANUFACT, szBuf,g_App.szOpkWizIniFile);
  253. // Store away the Manufacturer name for IE Branding page
  254. //
  255. lstrcpyn(g_App.szManufacturer, szBuf[0] ? szBuf : NULLSTR, AS(g_App.szManufacturer));
  256. // Model name.
  257. //
  258. GetDlgItemText(hwnd, IDC_INFO_MODEL, szBuf, MAX_INFOLEN);
  259. WritePrivateProfileString(INI_SEC_GENERAL, INI_KEY_MODELNAME, szBuf, g_App.szOemInfoIniFile);
  260. WritePrivateProfileString(INI_SEC_GENERAL, INI_KEY_MODELNAME, szBuf, g_App.szOpkWizIniFile);
  261. // If there isn't already a config name, use the model name as the default.
  262. //
  263. if ( g_App.szConfigName[0] == NULLCHR )
  264. lstrcpyn(g_App.szConfigName, szBuf, AS(g_App.szConfigName));
  265. // Support info.
  266. //
  267. // All this nonsense below does:
  268. //
  269. // 1. Reads a line from the edit.
  270. // 2. Prepends LineX=" to it (note the quote).
  271. // 3. Adds a " and null terminator onto the end (the API
  272. // used here does NOT null terminate the string).
  273. // 4. Writes the line to the approp. section.
  274. //
  275. // First remove the section, setup the buffer, and find out
  276. // many lines we are going to have to read in.
  277. //
  278. WritePrivateProfileString(INI_SEC_SUPPORT, NULL, NULL, g_App.szOemInfoIniFile);
  279. WritePrivateProfileString(INI_SEC_SUPPORT, NULL, NULL, g_App.szOpkWizIniFile);
  280. szBuf[0] = CHR_QUOTE;
  281. uCount = (UINT) SendDlgItemMessage(hwnd, IDC_INFO_SUPPORT, EM_GETLINECOUNT, 0, 0);
  282. for ( uIndex = 0; uIndex < uCount; uIndex++ )
  283. {
  284. // Setup how big the buffer is.
  285. //
  286. *((WORD *) (szBuf + 1)) = STRSIZE(szBuf);
  287. // Read a line in from the edit box.
  288. //
  289. uNumBytes = (UINT) SendDlgItemMessage(hwnd, IDC_INFO_SUPPORT, EM_GETLINE, (WPARAM) uIndex, (LPARAM) (szBuf + 1));
  290. // Add the trailing quote and the null terminator.
  291. //
  292. *(szBuf + uNumBytes + 1) = CHR_QUOTE;
  293. *(szBuf + uNumBytes + 2) = NULLCHR;
  294. // Now write it to the ini file.
  295. //
  296. hrPrintf=StringCchPrintf(szKeyBuf, AS(szKeyBuf), INI_KEY_SUPLINE, uIndex + 1);
  297. WritePrivateProfileString(INI_SEC_SUPPORT, szKeyBuf, szBuf, g_App.szOemInfoIniFile);
  298. WritePrivateProfileString(INI_SEC_SUPPORT, szKeyBuf, szBuf, g_App.szOpkWizIniFile);
  299. }
  300. }
  301. LONG CALLBACK SupportEditWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
  302. {
  303. static FARPROC lpfnOldProc = NULL;
  304. switch ( msg )
  305. {
  306. case EM_SETSEL:
  307. wParam = lParam = 0;
  308. PostMessage(hwnd, EM_SCROLLCARET, 0, 0L);
  309. break;
  310. case WM_CHAR:
  311. if ( wParam == KEY_ESC )
  312. WIZ_PRESS(GetParent(hwnd), PSBTN_CANCEL);
  313. break;
  314. case WM_SUBWNDPROC:
  315. lpfnOldProc = (FARPROC) GetWindowLongPtr(hwnd, GWLP_WNDPROC);
  316. SetWindowLongPtr(hwnd, GWLP_WNDPROC, (LONG_PTR)SupportEditWndProc);
  317. return 1;
  318. case WM_SETSEL:
  319. msg = EM_SETSEL;
  320. break;
  321. }
  322. if ( lpfnOldProc )
  323. return (LONG) CallWindowProc((WNDPROC) lpfnOldProc, hwnd, msg, wParam, lParam);
  324. else
  325. return 0;
  326. }