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.

962 lines
20 KiB

  1. /******************************Module*Header*******************************\
  2. * Module Name: database.c
  3. *
  4. * This module implements the database routines for the CD Audio app.
  5. * The information is stored in the ini file "cdaudio.ini" which should
  6. * be located in the nt\windows directory.
  7. *
  8. * Warning:
  9. * These functions ARE NOT THREAD safe.
  10. * The functions in this file MUST only be called on the UI thread. Before
  11. * calling any of the functions the CALLER MUST call LockTableOfContents
  12. * for the specified cdrom device.
  13. *
  14. * Author:
  15. * Rick Turner (ricktu) 31-Jan-1992
  16. *
  17. *
  18. * Revision History:
  19. *
  20. * 04-Aug-1992 (ricktu) Incorperated routines from old cdaudio.c,
  21. * and made work w/new child window framework.
  22. *
  23. *
  24. * Copyright (c) 1993 - 1995 Microsoft Corporation. All rights reserved.
  25. \**************************************************************************/
  26. #pragma warning( once : 4201 4214 )
  27. #define NOOLE
  28. #include <windows.h>
  29. #include "playres.h"
  30. #include "cdapi.h"
  31. #include "cdplayer.h"
  32. #include "database.h"
  33. #include "literals.h"
  34. #include <string.h>
  35. #include <stdio.h>
  36. #include <tchar.h>
  37. #include "trklst.h"
  38. #include "..\cdnet\cdnet.h"
  39. #include "..\cdopt\cdopt.h"
  40. /* -------------------------------------------------------------------------
  41. ** Private entry points
  42. ** -------------------------------------------------------------------------
  43. */
  44. DWORD
  45. ComputeOldDiscId(
  46. int cdrom
  47. );
  48. BOOL
  49. ReadEntry(
  50. int cdrom,
  51. DWORD dwId);
  52. /*****************************Private*Routine******************************\
  53. * ComputeOldDiscId
  54. *
  55. * This routine computes a unique ID based on the information
  56. * in the table of contexts a given disc.
  57. *
  58. *
  59. * History:
  60. * 18-11-93 - ricktu - Created
  61. *
  62. \**************************************************************************/
  63. DWORD
  64. ComputeOldDiscId(
  65. int cdrom
  66. )
  67. {
  68. int NumTracks,i;
  69. DWORD DiscId = 0;
  70. NumTracks = g_Devices[ cdrom ]->toc.LastTrack -
  71. g_Devices[ cdrom ]->toc.FirstTrack;
  72. for ( i = 0; i < NumTracks; i++ ) {
  73. DiscId += ( (TRACK_M(cdrom,i) << 16) +
  74. (TRACK_S(cdrom,i) << 8) +
  75. TRACK_F(cdrom,i) );
  76. }
  77. return DiscId;
  78. }
  79. /******************************Public*Routine******************************\
  80. * ComputeNewDiscId
  81. *
  82. * Just call mci to get the product ID.
  83. *
  84. * History:
  85. * dd-mm-94 - StephenE - Created
  86. *
  87. \**************************************************************************/
  88. DWORD
  89. ComputeNewDiscId(
  90. int cdrom
  91. )
  92. {
  93. #ifdef USE_IOCTLS
  94. return ComputeOrgDiscId( cdrom );
  95. #else
  96. MCI_INFO_PARMS mciInfo;
  97. TCHAR szBuffer[32];
  98. DWORD dwRet;
  99. mciInfo.lpstrReturn = szBuffer;
  100. mciInfo.dwRetSize = sizeof(szBuffer)/sizeof(TCHAR);
  101. dwRet = mciSendCommand( g_Devices[cdrom]->hCd, MCI_INFO,
  102. MCI_INFO_MEDIA_IDENTITY,
  103. (DWORD_PTR)(LPVOID)&mciInfo );
  104. if ( dwRet != MMSYSERR_NOERROR ) {
  105. return 0L;
  106. }
  107. _stscanf(szBuffer, TEXT("%ld"), &dwRet );
  108. return dwRet;
  109. #endif
  110. }
  111. /*****************************Private*Routine******************************\
  112. * ComputeOrgDiscId
  113. *
  114. * This routine computes a unique ID based on the information
  115. * in the table of contexts a given disc. This is done by taking
  116. * the TMSF value for each track and XOR'ing it with the previous
  117. * quantity shifted left one bit.
  118. *
  119. *
  120. * History:
  121. * 18-11-93 - ricktu - Created
  122. *
  123. \**************************************************************************/
  124. DWORD
  125. ComputeOrgDiscId(
  126. int cdrom
  127. )
  128. {
  129. int NumTracks,i;
  130. DWORD DiscId = 0;
  131. NumTracks = g_Devices[ cdrom ]->toc.LastTrack -
  132. g_Devices[ cdrom ]->toc.FirstTrack + 1;
  133. for ( i = 0; i < NumTracks; i++ ) {
  134. DiscId = (DiscId << 1) ^
  135. ((i<<24) +
  136. (TRACK_M(cdrom,i) << 16) +
  137. (TRACK_S(cdrom,i) << 8) +
  138. TRACK_F(cdrom,i) );
  139. }
  140. return DiscId;
  141. }
  142. /*****************************Private*Routine******************************\
  143. * ErasePlayList
  144. *
  145. * Erases the current play list. This includes freeing the memory
  146. * for the nodes in the play list, and resetting the current track
  147. * pointer to NULL.
  148. *
  149. *
  150. * History:
  151. * 18-11-93 - ricktu - Created
  152. *
  153. \**************************************************************************/
  154. VOID
  155. ErasePlayList(
  156. int cdrom
  157. )
  158. {
  159. PTRACK_PLAY temp, temp1;
  160. //
  161. // Free memory for each track in play list
  162. //
  163. temp = PLAYLIST( cdrom );
  164. while (temp!=NULL) {
  165. temp1 = temp->nextplay;
  166. LocalFree( (HLOCAL)temp );
  167. temp = temp1;
  168. }
  169. //
  170. // Reset pointers
  171. //
  172. PLAYLIST( cdrom ) = NULL;
  173. CURRTRACK( cdrom ) = NULL;
  174. }
  175. /******************************Public*Routine******************************\
  176. * EraseSaveList
  177. *
  178. * Erases the current save list. This includes freeing the memory
  179. * for the nodes in the save list.
  180. *
  181. *
  182. * History:
  183. * 18-11-93 - ricktu - Created
  184. *
  185. \**************************************************************************/
  186. VOID
  187. EraseSaveList(
  188. int cdrom
  189. )
  190. {
  191. PTRACK_PLAY temp, temp1;
  192. //
  193. // Free memory for each track in play list
  194. //
  195. temp = SAVELIST( cdrom );
  196. while ( temp != NULL ) {
  197. temp1 = temp->nextplay;
  198. LocalFree( (HLOCAL)temp );
  199. temp = temp1;
  200. }
  201. //
  202. // Reset pointers
  203. //
  204. SAVELIST( cdrom ) = NULL;
  205. }
  206. /*****************************Private*Routine******************************\
  207. * EraseTrackList
  208. *
  209. * Erases the current track list. This includes freeing the memory
  210. * for the nodes in the track list, and resetting the track list
  211. * pointer to NULL.
  212. *
  213. *
  214. * History:
  215. * 18-11-93 - ricktu - Created
  216. *
  217. \**************************************************************************/
  218. VOID
  219. EraseTrackList(
  220. int cdrom
  221. )
  222. {
  223. PTRACK_INF temp, temp1;
  224. //
  225. // Free memory for each track in track list
  226. //
  227. temp = ALLTRACKS( cdrom );
  228. while ( temp != NULL ) {
  229. temp1 = temp->next;
  230. LocalFree( (HLOCAL)temp );
  231. temp = temp1;
  232. }
  233. //
  234. // Reset pointers
  235. //
  236. ALLTRACKS( cdrom ) = NULL;
  237. }
  238. /******************************Public*Routine******************************\
  239. * CopyPlayList
  240. *
  241. * Returns a copy of the playlist pointed to by p.
  242. *
  243. *
  244. * History:
  245. * 18-11-93 - ricktu - Created
  246. *
  247. \**************************************************************************/
  248. PTRACK_PLAY
  249. CopyPlayList(
  250. PTRACK_PLAY p
  251. )
  252. {
  253. PTRACK_PLAY t,t1,tend,tret;
  254. tret = tend = NULL;
  255. //
  256. // Duplicate list pointed to by p.
  257. //
  258. t = p;
  259. while( t!=NULL ) {
  260. t1 = (PTRACK_PLAY)AllocMemory( sizeof(TRACK_PLAY) );
  261. t1->TocIndex = t->TocIndex;
  262. t1->min = t->min;
  263. t1->sec = t->sec;
  264. t1->nextplay = NULL;
  265. t1->prevplay = tend;
  266. if (tret==NULL) {
  267. tret = tend = t1;
  268. }
  269. else {
  270. tend->nextplay = t1;
  271. tend = t1;
  272. }
  273. t = t->nextplay;
  274. }
  275. return(tret);
  276. }
  277. /*****************************Private*Routine******************************\
  278. * ResetPlayList
  279. *
  280. * Resets play order for the disc. Used to initialize/reset
  281. * the play list. This is done by reseting the doubly-linked list
  282. * of tracks in the g_Devices[...]->CdInfo.PlayList.[prevplay,nextplay]
  283. * pointers. All the tracks on the CD are stored in a singly linked list
  284. * pointed to by g_Devices[...]->CdInfo.AllTracks pointer.
  285. *
  286. *
  287. * History:
  288. * 18-11-93 - ricktu - Created
  289. *
  290. \**************************************************************************/
  291. VOID
  292. ResetPlayList(
  293. int cdrom
  294. )
  295. {
  296. PTRACK_INF t;
  297. PTRACK_PLAY temp, prev;
  298. //
  299. // Kill old play list
  300. //
  301. ErasePlayList( cdrom );
  302. EraseSaveList( cdrom );
  303. //
  304. // Duplicate each node in AllTracks and insert in-order
  305. // in SaveList list. The SaveList is the master which is
  306. // used for the playlist.
  307. //
  308. t = ALLTRACKS( cdrom );
  309. prev = NULL;
  310. while (t!=NULL) {
  311. temp = (PTRACK_PLAY)AllocMemory( sizeof(TRACK_PLAY) );
  312. temp->TocIndex = t->TocIndex;
  313. temp->min = 0;
  314. temp->sec = 0;
  315. temp->prevplay = prev;
  316. temp->nextplay = NULL;
  317. if (prev!=NULL) {
  318. prev->nextplay = temp;
  319. }
  320. else {
  321. SAVELIST( cdrom ) = temp;
  322. }
  323. prev = temp;
  324. t=t->next;
  325. }
  326. PLAYLIST( cdrom ) = CopyPlayList( SAVELIST( cdrom) );
  327. }
  328. void RecomputePlayTimes(int dCdrom)
  329. {
  330. /*
  331. ** Compute PLAY length
  332. */
  333. PTRACK_PLAY pp;
  334. int m, s, mtemp, stemp;
  335. m = s = 0;
  336. for( pp = PLAYLIST(dCdrom); pp != NULL; pp = pp->nextplay )
  337. {
  338. FigureTrackTime( dCdrom, pp->TocIndex, &mtemp, &stemp );
  339. m+=mtemp;
  340. s+=stemp;
  341. pp->min = mtemp;
  342. pp->sec = stemp;
  343. }
  344. //also refresh the savelist
  345. for( pp = SAVELIST(dCdrom); pp != NULL; pp = pp->nextplay )
  346. {
  347. FigureTrackTime( dCdrom, pp->TocIndex, &mtemp, &stemp );
  348. pp->min = mtemp;
  349. pp->sec = stemp;
  350. }
  351. m += (s / 60);
  352. s = (s % 60);
  353. CDTIME(dCdrom).TotalMin = m;
  354. CDTIME(dCdrom).TotalSec = s;
  355. /*
  356. ** Make sure that the track time displayed in the LED and the
  357. ** status bar is correct. If we have a current track and the
  358. ** CD is playing or paused then everything is OK. Otherwise, we
  359. ** have to reset the track times.
  360. */
  361. if ( CURRTRACK( dCdrom ) != NULL ) {
  362. if ( STATE(dCdrom) & CD_STOPPED ) {
  363. CDTIME(dCdrom).TrackTotalMin = CURRTRACK( dCdrom )->min;
  364. CDTIME(dCdrom).TrackRemMin = CURRTRACK( dCdrom )->min;
  365. CDTIME(dCdrom).TrackTotalSec = CURRTRACK( dCdrom )->sec;
  366. CDTIME(dCdrom).TrackRemSec = CURRTRACK( dCdrom )->sec;
  367. }
  368. }
  369. else {
  370. CDTIME(dCdrom).TrackTotalMin = 0;
  371. CDTIME(dCdrom).TrackRemMin = 0;
  372. CDTIME(dCdrom).TrackTotalSec = 0;
  373. CDTIME(dCdrom).TrackRemSec = 0;
  374. }
  375. if (dCdrom == g_CurrCdrom)
  376. {
  377. UpdateDisplay( DISPLAY_UPD_DISC_TIME );
  378. }
  379. }
  380. void CreateNewEntry(int cdrom, DWORD key, PCDROM_TOC lpTOC)
  381. {
  382. /*
  383. ** This is a new entry, fill it in but don't store it in the database.
  384. */
  385. PTRACK_INF temp, temp1;
  386. PTRACK_PLAY pTempCurrTrack = CURRTRACK(cdrom);
  387. int i, num;
  388. int nSaveTrack = -1;
  389. if (CURRTRACK(cdrom))
  390. {
  391. nSaveTrack = CURRTRACK(cdrom)->TocIndex;
  392. }
  393. ErasePlayList( cdrom );
  394. EraseSaveList( cdrom );
  395. EraseTrackList( cdrom );
  396. g_Devices[ cdrom ]->CdInfo.iFrameOffset = NEW_FRAMEOFFSET;
  397. g_Devices[ cdrom ]->CdInfo.IsVirginCd = TRUE;
  398. g_Devices[ cdrom ]->CdInfo.Id = key;
  399. wsprintf( (LPTSTR)ARTIST( cdrom ), IdStr( STR_NEW_ARTIST ) );
  400. wsprintf( (LPTSTR)TITLE( cdrom ), IdStr( STR_NEW_TITLE ) );
  401. if (lpTOC)
  402. {
  403. NUMTRACKS( cdrom ) = num = lpTOC->LastTrack - lpTOC->FirstTrack + 1;
  404. }
  405. else
  406. {
  407. num = NUMTRACKS( cdrom );
  408. }
  409. /*
  410. ** Create generic playlist, which is all audio tracks
  411. ** played in the order they are on the CD. First, create
  412. ** a singly linked list that contains all the tracks.
  413. ** Then, create a double linked list, using the nodes of
  414. ** from the single linked list for the play list.
  415. */
  416. for( i = 0; i < num; i++ ) {
  417. /*
  418. ** Create storage for track
  419. */
  420. temp = (PTRACK_INF)AllocMemory( sizeof(TRACK_INF) );
  421. /*
  422. ** Initialize information (storage already ZERO initialized)
  423. */
  424. wsprintf( (LPTSTR)temp->name, IdStr( STR_INIT_TRACK ), i+1 );
  425. temp->TocIndex = i;
  426. temp->next = NULL;
  427. /*
  428. ** Add node to singly linked list of all tracks
  429. */
  430. if (i == 0) {
  431. temp1 = ALLTRACKS( cdrom ) = temp;
  432. }
  433. else {
  434. temp1->next = temp;
  435. temp1 = temp;
  436. }
  437. }
  438. /*
  439. ** Generate generic play list (all tracks in order)
  440. */
  441. ResetPlayList( cdrom );
  442. if (nSaveTrack > -1)
  443. {
  444. PTRACK_PLAY playlist;
  445. for( playlist = PLAYLIST(cdrom);
  446. playlist != NULL;
  447. playlist = playlist->nextplay )
  448. {
  449. if (playlist->TocIndex == nSaveTrack)
  450. {
  451. CURRTRACK(cdrom) = playlist;
  452. }
  453. }
  454. }
  455. if (!g_fSelectedOrder)
  456. {
  457. ComputeSingleShufflePlayList(cdrom);
  458. }
  459. RecomputePlayTimes(cdrom);
  460. }
  461. BOOL GetInternetDatabase(int cdrom, DWORD key, BOOL fHitNet, BOOL fManual, HWND hwndCallback, void* pData)
  462. {
  463. if (!g_fBlockNetPrompt)
  464. {
  465. if (fHitNet)
  466. {
  467. ICDNet* pICDNet = NULL;
  468. if (SUCCEEDED(CDNET_CreateInstance(NULL, IID_ICDNet, (void**)&pICDNet)))
  469. {
  470. pICDNet->SetOptionsAndData((void*)g_pSink->GetOptions(),(void*)g_pSink->GetData());
  471. pICDNet->Download(g_Devices[ cdrom ]->hCd,g_Devices[cdrom]->drive,key,(LPCDTITLE)pData,fManual,hwndCallback);
  472. pICDNet->Release();
  473. }
  474. return FALSE; //couldn't find title just now, catch it on the callback
  475. }
  476. }
  477. if ( ReadEntry(cdrom, key))
  478. {
  479. return TRUE;
  480. }
  481. if (!fHitNet)
  482. {
  483. CreateNewEntry(cdrom, key, NULL);
  484. RecomputePlayTimes(cdrom);
  485. }
  486. return FALSE;
  487. }
  488. /*****************************Private*Routine******************************\
  489. * ReadEntry
  490. *
  491. * Try to read entry for new disc from database ini file.
  492. * The section name we are trying to read is a hex
  493. * value of the disc id. If the sections is found,
  494. * fill in the data for the disc in the cdrom drive.
  495. *
  496. * This function uses over 16K of stack space !!
  497. *
  498. * History:
  499. * 18-11-93 - ricktu - Created
  500. *
  501. \**************************************************************************/
  502. BOOL
  503. ReadEntry(
  504. int cdrom,
  505. DWORD dwId)
  506. {
  507. UINT i;
  508. int numtracks, numplay;
  509. PTRACK_INF temp, curr;
  510. PTRACK_PLAY temp1, prev;
  511. BOOL fRewriteEntry = FALSE;
  512. LPCDDATA pData = NULL;
  513. g_Devices[ cdrom ]->CdInfo.iFrameOffset = NEW_FRAMEOFFSET;
  514. pData = (LPCDDATA)g_pSink->GetData();
  515. if( !pData )
  516. {
  517. //Can't create the options object, so fail
  518. return (FALSE);
  519. }
  520. pData->AddRef();
  521. //
  522. // Try to read in title from the options database
  523. //
  524. if (!pData->QueryTitle(dwId))
  525. {
  526. pData->Release();
  527. return (FALSE);
  528. }
  529. //
  530. // We found an entry for this disc, so copy all the information
  531. // from the title database
  532. LPCDTITLE pCDTitle = NULL;
  533. if (FAILED(pData->LockTitle(&pCDTitle,dwId)))
  534. {
  535. pData->Release();
  536. return FALSE;
  537. }
  538. _tcscpy(g_Devices[ cdrom ]->CdInfo.Title,pCDTitle->szTitle);
  539. numtracks = pCDTitle->dwNumTracks;
  540. // Make sure there is at least one track!!!
  541. if (0 == numtracks)
  542. {
  543. fRewriteEntry = TRUE;
  544. }
  545. g_Devices[ cdrom ]->CdInfo.NumTracks = numtracks;
  546. _tcscpy(g_Devices[ cdrom ]->CdInfo.Artist,pCDTitle->szArtist);
  547. //
  548. // Validate the stored track numbers
  549. //
  550. if (g_Devices[cdrom]->fIsTocValid)
  551. {
  552. int maxTracks; // validate the high point in database
  553. maxTracks = g_Devices[cdrom]->toc.LastTrack;
  554. if (numtracks > maxTracks)
  555. {
  556. // Current database contains invalid data
  557. // this can result in the CD not playing at all as the end
  558. // point is likely to be invalid
  559. g_Devices[ cdrom ]->CdInfo.NumTracks
  560. = numtracks
  561. = maxTracks;
  562. fRewriteEntry = TRUE;
  563. }
  564. }
  565. //
  566. // Read the track list information
  567. //
  568. for (i=0, curr = NULL; i < (UINT)numtracks; i++)
  569. {
  570. temp = (PTRACK_INF)AllocMemory( sizeof(TRACK_INF) );
  571. temp->TocIndex = i;
  572. temp->next = NULL;
  573. _tcscpy(temp->name,pCDTitle->pTrackTable[i].szName);
  574. if (curr==NULL)
  575. {
  576. ALLTRACKS( cdrom ) = curr = temp;
  577. } else
  578. {
  579. curr->next = temp;
  580. curr = temp;
  581. }
  582. }
  583. // Make sure there is at least one entry in TRACK list
  584. if (ALLTRACKS(cdrom) == NULL)
  585. {
  586. fRewriteEntry = TRUE;
  587. }
  588. //
  589. // if we detected a problem in the ini file, or the entry is an
  590. // old format, rewrite the section.
  591. //
  592. if (fRewriteEntry)
  593. {
  594. //
  595. // Generate generic play list (all tracks in order)
  596. //
  597. ResetPlayList( cdrom );
  598. if (!g_fSelectedOrder)
  599. {
  600. ComputeSingleShufflePlayList(cdrom);
  601. }
  602. RecomputePlayTimes(cdrom);
  603. }
  604. else
  605. {
  606. //
  607. // Read play list (order) information and construct play list doubly
  608. // linked list
  609. //
  610. numplay = pCDTitle->dwNumPlay;
  611. if (numplay == 0)
  612. {
  613. numplay = pCDTitle->dwNumTracks;
  614. }
  615. prev = NULL;
  616. int iCurrTrack = -1;
  617. if (CURRTRACK(cdrom)!=NULL)
  618. {
  619. iCurrTrack = CURRTRACK(cdrom)->TocIndex;
  620. }
  621. EraseSaveList(cdrom);
  622. ErasePlayList(cdrom);
  623. for (int tr_index = 0; tr_index < numplay; tr_index++)
  624. {
  625. /*
  626. ** Assert that i is a valid index.
  627. ** ie 0 <= i <= (numtracks - 1)
  628. */
  629. if (pCDTitle->dwNumPlay > 0)
  630. {
  631. i = pCDTitle->pPlayList[tr_index];
  632. }
  633. else
  634. {
  635. i = tr_index;
  636. }
  637. i = min( ((UINT)numtracks - 1), i );
  638. temp1 = (PTRACK_PLAY)AllocMemory( sizeof(TRACK_PLAY) );
  639. temp1->TocIndex = (int)i;
  640. temp1->min = 0;
  641. temp1->sec = 0;
  642. temp1->prevplay = prev;
  643. temp1->nextplay = NULL;
  644. if (prev==NULL)
  645. {
  646. SAVELIST( cdrom ) = temp1;
  647. }
  648. else
  649. {
  650. prev->nextplay = temp1;
  651. }
  652. prev = temp1;
  653. }
  654. // Make sure there is at least one entry in SAVED list
  655. if (SAVELIST(cdrom) == NULL)
  656. {
  657. // Nope, use default list instead
  658. ResetPlayList( cdrom );
  659. }
  660. PLAYLIST( cdrom ) = CopyPlayList( SAVELIST( cdrom ) );
  661. //reset current track if necessary
  662. if (iCurrTrack != -1)
  663. {
  664. BOOL fFound = FALSE;
  665. for (PTRACK_PLAY pp = PLAYLIST(cdrom); pp != NULL; pp = pp->nextplay )
  666. {
  667. if ( pp->TocIndex == iCurrTrack )
  668. {
  669. fFound = TRUE;
  670. break;
  671. }
  672. } //end for
  673. if (fFound)
  674. {
  675. CURRTRACK(cdrom) = pp;
  676. }
  677. else
  678. {
  679. /*
  680. ** If the track was not found in the new track list and this
  681. ** cd is currently playing then stop it.
  682. */
  683. if ( (STATE(cdrom) & (CD_PLAYING | CD_PAUSED)) )
  684. {
  685. SendDlgItemMessage( g_hwndApp, IDM_PLAYBAR_STOP,
  686. WM_LBUTTONDOWN, 1, 0 );
  687. SendDlgItemMessage( g_hwndApp, IDM_PLAYBAR_STOP,
  688. WM_LBUTTONUP, 1, 0 );
  689. }
  690. CURRTRACK(cdrom) = PLAYLIST(cdrom);
  691. }
  692. }
  693. /*
  694. ** If we were previously in "Random" mode shuffle the new
  695. ** playlist.
  696. */
  697. if (!g_fSelectedOrder)
  698. {
  699. ComputeSingleShufflePlayList(cdrom);
  700. }
  701. RecomputePlayTimes(cdrom);
  702. }
  703. //unlock title data, don't persist it
  704. pData->UnlockTitle(pCDTitle,FALSE);
  705. pData->Release();
  706. return TRUE;
  707. }
  708. /******************************Public*Routine******************************\
  709. * AddFindEntry
  710. *
  711. * Search the database file for the current disc, if found, read the
  712. * information, otherwise, generate some default artist and track names etc.
  713. * but don't store this in the database. A new entry is only added to the
  714. * database after the user has used the "Edit Track Titles" dialog box.
  715. *
  716. * The design of this function is complicated by the fact that we have to
  717. * support two previous attempts at generating CDplayer keys. Also, we try
  718. * to support the MusicBox key format now that it is compatible with the
  719. * new CDplayer format.
  720. *
  721. *
  722. * History:
  723. * 18-11-93 - ricktu - Created
  724. *
  725. \**************************************************************************/
  726. VOID
  727. AddFindEntry(
  728. int cdrom,
  729. DWORD key,
  730. PCDROM_TOC lpTOC
  731. )
  732. {
  733. /*
  734. ** Kill off old PlayList, Save lists if they exists.
  735. */
  736. ErasePlayList( cdrom );
  737. EraseSaveList( cdrom );
  738. EraseTrackList( cdrom );
  739. /*
  740. ** Check ini file for an existing entry
  741. **
  742. ** First Look in cdplayer.ini using the new key, return if found
  743. */
  744. // We initialize this field early, otherwise ReadEntry will not be
  745. // able to save any new information (or lose invalid).
  746. g_Devices[ cdrom ]->CdInfo.save = TRUE;
  747. if ( ReadEntry(cdrom, key) )
  748. {
  749. return;
  750. }
  751. /*
  752. ** Initialize these fields
  753. */
  754. g_Devices[ cdrom ]->CdInfo.IsVirginCd = FALSE;
  755. g_Devices[ cdrom ]->CdInfo.Id = key;
  756. /*
  757. ** dstewart: Try to get the info from the net
  758. */
  759. if ( GetInternetDatabase(cdrom, key, TRUE, FALSE, GetParent(g_hwndApp),NULL) )
  760. {
  761. return;
  762. }
  763. /*
  764. ** end dstewart
  765. */
  766. CreateNewEntry(cdrom,key,lpTOC);
  767. }