File: DiscIDWrapper.cc

package info (click to toggle)
flactag 2.0.4-5
  • links: PTS, VCS
  • area: main
  • in suites: bullseye, buster, sid, stretch
  • size: 2,096 kB
  • ctags: 477
  • sloc: sh: 10,777; cpp: 3,283; makefile: 62; sed: 7
file content (85 lines) | stat: -rwxr-xr-x 2,315 bytes parent folder | download | duplicates (3)
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
/* --------------------------------------------------------------------------

   flactag -- A tagger for single album FLAC files with embedded CUE sheets
   						using data retrieved from the MusicBrainz service

   Copyright (C) 2006-2007 Andrew Hawkins

   This file is part of flactag.

   This program is free software: you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
	 the Free Software Foundation, either version 3 of the License, or
	 (at your option) any later version.

   Flactag is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.

   You should have received a copy of the GNU General Public
   License along with this library; if not, write to the Free Software
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

     $Id$

----------------------------------------------------------------------------*/

#include "DiscIDWrapper.h"

CDiscIDWrapper::CDiscIDWrapper()
:	m_DiscID(discid_new())
{
}

CDiscIDWrapper::~CDiscIDWrapper()
{
	if (m_DiscID)
		discid_free(m_DiscID);
}

bool CDiscIDWrapper::FromDevice(const std::string& Device)
{
	return discid_read(m_DiscID,Device.c_str());
}

bool CDiscIDWrapper::FromCuesheet(const CCuesheet& Cuesheet)
{
	std::vector<int> Offsets;

	for (int count=Cuesheet.FirstTrack();count<=Cuesheet.LastTrack();count++)
		Offsets.push_back(Cuesheet.Track(count).Offset());

	return FromTOC(Cuesheet.FirstTrack(),Cuesheet.LastTrack(),Cuesheet.Leadout(),Offsets);
}

bool CDiscIDWrapper::FromTOC(int First, int Last, int Leadout, std::vector<int> Offsets)
{
	int *OffsetsArray=new int[Last+1];

	OffsetsArray[0]=Leadout;

	for (std::vector<int>::size_type count=0;count<Offsets.size();count++)
		OffsetsArray[count+1]=Offsets[count];

	bool RetVal=discid_put(m_DiscID,First,Last,OffsetsArray);

	delete[] OffsetsArray;

	return RetVal;
}

std::string CDiscIDWrapper::ID() const
{
	return discid_get_id(m_DiscID);
}

std::string CDiscIDWrapper::SubmitURL() const
{
	return discid_get_submission_url(m_DiscID);
}

std::string CDiscIDWrapper::Error() const
{
	return discid_get_error_msg(m_DiscID);
}