aboutsummaryrefslogtreecommitdiffstats
path: root/print/kcdlabel/files/patch-audiocd.cpp
blob: 3ee6abd6ae86c131cc33ac952896ee638a51bac4 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
--- kcdlabel/audiocd.cpp.orig   Mon Dec 29 01:15:28 2003
+++ kcdlabel/audiocd.cpp    Mon Dec 29 02:15:09 2003
@@ -58,8 +58,13 @@
 
 bool AudioCD::readTOC()
 {
+#ifdef __FreeBSD__
+   struct ioc_toc_header tochdr;
+   struct ioc_read_toc_single_entry tocentry;
+#else
    struct cdrom_tochdr tochdr;
    struct cdrom_tocentry tocentry;
+#endif
    int i;
 
    emit statusText((char *)"Reading Toc...");
@@ -73,36 +78,61 @@
        return(false);
        }
        
+#ifdef __FreeBSD__
+   if (ioctl(cdromfd, CDIOREADTOCHEADER, &tochdr) == -1)
+#else
    if (ioctl(cdromfd,CDROMREADTOCHDR,&tochdr) == -1)
+#endif
        {
        emit statusText((char *)"Read Toc - Read TOC Header error");
        close(cdromfd);
        return(false);
        }
 
+#ifdef __FreeBSD__
+   tocentry.address_format = CD_MSF_FORMAT;
+   for (i = tochdr.starting_track; i <= tochdr.ending_track; i++) {
+       tocentry.track = i;
+       if (ioctl(cdromfd, CDIOREADTOCENTRY, &tocentry) == -1)
+#else
    tocentry.cdte_format = CDROM_MSF;
    for (i=tochdr.cdth_trk0;i<=tochdr.cdth_trk1;i++)
        {
        tocentry.cdte_track = i;
        if (ioctl(cdromfd,CDROMREADTOCENTRY,&tocentry) == -1)
+#endif
            {
            emit statusText((char *)"Read Toc - Read TOC Entry error");
            close(cdromfd);
            return(false);
            }
+#ifdef __FreeBSD__
+       TOC[nr_tracks++] = tocentry.entry;
+       TrackOffsets.push_back( (TOC[nr_tracks-1].addr.msf.minute*60+TOC[nr_tracks-1].addr.msf.second)*75+TOC[nr_tracks-1].addr.msf.frame ); 
+       }
+   tocentry.track = CDROM_LEADOUT;
+   if (ioctl(cdromfd, CDIOREADTOCENTRY, &tocentry) == -1)
+#else
        TOC[nr_tracks++] = tocentry.cdte_addr.msf;
        TrackOffsets.push_back( (TOC[nr_tracks-1].minute*60+TOC[nr_tracks-1].second)*75+TOC[nr_tracks-1].frame );
        }
    tocentry.cdte_track = CDROM_LEADOUT;
    if (ioctl(cdromfd,CDROMREADTOCENTRY,&tocentry) == -1)
+#endif
        {
        emit statusText((char *)"Read Toc - Read TOC Entry (Lead-out) error");
        close(cdromfd);
        return(false);
         }
+#ifdef __FreeBSD__
+   TOC[nr_tracks] = tocentry.entry;
+   // cd length in seconds
+   CDLength = TOC[nr_tracks].addr.msf.minute*60 + TOC[nr_tracks].addr.msf.second;
+#else
    TOC[nr_tracks] = tocentry.cdte_addr.msf;
    // cd length in seconds
    CDLength = TOC[nr_tracks].minute*60 + TOC[nr_tracks].second;
+#endif
    // close the cdrom device
    close(cdromfd);
    TOCAvailable=true;
@@ -120,10 +150,18 @@
        
    while ( i < nr_tracks )
        {
+#ifdef __FreeBSD__
+       n = n + cddb_sum( ( TOC[i].addr.msf.minute * 60 ) + TOC[i].addr.msf.second );
+#else
        n = n + cddb_sum( ( TOC[i].minute * 60 ) + TOC[i].second );
+#endif
        i++;
        }
+#ifdef __FreeBSD__
+   t = (( TOC[nr_tracks].addr.msf.minute * 60 ) + TOC[nr_tracks].addr.msf.second ) - (( TOC[0].addr.msf.minute * 60)+ TOC[0].addr.msf.second );
+#else
    t = (( TOC[nr_tracks].minute * 60 ) + TOC[nr_tracks].second ) - (( TOC[0].minute * 60)+ TOC[0].second );
+#endif
    // get the discid in unsigned long
    ulDiscID = (( n % 0xff) << 24 | t << 8 | nr_tracks);
    // format the disc id to get a hexdecimal 8 digits string