metadata_object.cpp
上传用户:wstnjxml
上传日期:2014-04-03
资源大小:7248k
文件大小:63k
源码类别:

Windows CE

开发平台:

C/C++

  1. /* test_libFLAC++ - Unit tester for libFLAC++
  2.  * Copyright (C) 2002,2003,2004,2005  Josh Coalson
  3.  *
  4.  * This program is free software; you can redistribute it and/or
  5.  * modify it under the terms of the GNU General Public License
  6.  * as published by the Free Software Foundation; either version 2
  7.  * of the License, or (at your option) any later version.
  8.  *
  9.  * This program is distributed in the hope that it will be useful,
  10.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12.  * GNU General Public License for more details.
  13.  *
  14.  * You should have received a copy of the GNU General Public License
  15.  * along with this program; if not, write to the Free Software
  16.  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
  17.  */
  18. #include "FLAC/assert.h"
  19. #include "FLAC++/metadata.h"
  20. #include <stdio.h>
  21. #include <stdlib.h> /* for malloc() */
  22. #include <string.h> /* for memcmp() */
  23. static ::FLAC__StreamMetadata streaminfo_, padding_, seektable_, application_, vorbiscomment_, cuesheet_;
  24. static bool die_(const char *msg)
  25. {
  26. printf("FAILED, %sn", msg);
  27. return false;
  28. }
  29. static void *malloc_or_die_(size_t size)
  30. {
  31. void *x = malloc(size);
  32. if(0 == x) {
  33. fprintf(stderr, "ERROR: out of memory allocating %u bytesn", (unsigned)size);
  34. exit(1);
  35. }
  36. return x;
  37. }
  38. static bool index_is_equal_(const ::FLAC__StreamMetadata_CueSheet_Index &index, const ::FLAC__StreamMetadata_CueSheet_Index &indexcopy)
  39. {
  40. if(indexcopy.offset != index.offset)
  41. return false;
  42. if(indexcopy.number != index.number)
  43. return false;
  44. return true;
  45. }
  46. static bool track_is_equal_(const ::FLAC__StreamMetadata_CueSheet_Track *track, const ::FLAC__StreamMetadata_CueSheet_Track *trackcopy)
  47. {
  48. unsigned i;
  49. if(trackcopy->offset != track->offset)
  50. return false;
  51. if(trackcopy->number != track->number)
  52. return false;
  53. if(0 != strcmp(trackcopy->isrc, track->isrc))
  54. return false;
  55. if(trackcopy->type != track->type)
  56. return false;
  57. if(trackcopy->pre_emphasis != track->pre_emphasis)
  58. return false;
  59. if(trackcopy->num_indices != track->num_indices)
  60. return false;
  61. if(0 == track->indices || 0 == trackcopy->indices) {
  62. if(track->indices != trackcopy->indices)
  63. return false;
  64. }
  65. else {
  66. for(i = 0; i < track->num_indices; i++) {
  67. if(!index_is_equal_(trackcopy->indices[i], track->indices[i]))
  68. return false;
  69. }
  70. }
  71. return true;
  72. }
  73. static void init_metadata_blocks_()
  74. {
  75. streaminfo_.is_last = false;
  76. streaminfo_.type = ::FLAC__METADATA_TYPE_STREAMINFO;
  77. streaminfo_.length = FLAC__STREAM_METADATA_STREAMINFO_LENGTH;
  78. streaminfo_.data.stream_info.min_blocksize = 576;
  79. streaminfo_.data.stream_info.max_blocksize = 576;
  80. streaminfo_.data.stream_info.min_framesize = 0;
  81. streaminfo_.data.stream_info.max_framesize = 0;
  82. streaminfo_.data.stream_info.sample_rate = 44100;
  83. streaminfo_.data.stream_info.channels = 1;
  84. streaminfo_.data.stream_info.bits_per_sample = 8;
  85. streaminfo_.data.stream_info.total_samples = 0;
  86. memset(streaminfo_.data.stream_info.md5sum, 0, 16);
  87. padding_.is_last = false;
  88. padding_.type = ::FLAC__METADATA_TYPE_PADDING;
  89. padding_.length = 1234;
  90. seektable_.is_last = false;
  91. seektable_.type = ::FLAC__METADATA_TYPE_SEEKTABLE;
  92. seektable_.data.seek_table.num_points = 2;
  93. seektable_.length = seektable_.data.seek_table.num_points * FLAC__STREAM_METADATA_SEEKPOINT_LENGTH;
  94. seektable_.data.seek_table.points = (::FLAC__StreamMetadata_SeekPoint*)malloc_or_die_(seektable_.data.seek_table.num_points * sizeof(::FLAC__StreamMetadata_SeekPoint));
  95. seektable_.data.seek_table.points[0].sample_number = 0;
  96. seektable_.data.seek_table.points[0].stream_offset = 0;
  97. seektable_.data.seek_table.points[0].frame_samples = streaminfo_.data.stream_info.min_blocksize;
  98. seektable_.data.seek_table.points[1].sample_number = ::FLAC__STREAM_METADATA_SEEKPOINT_PLACEHOLDER;
  99. seektable_.data.seek_table.points[1].stream_offset = 1000;
  100. seektable_.data.seek_table.points[1].frame_samples = streaminfo_.data.stream_info.min_blocksize;
  101. application_.is_last = false;
  102. application_.type = ::FLAC__METADATA_TYPE_APPLICATION;
  103. application_.length = 8;
  104. memcpy(application_.data.application.id, "xfexdcxbax98", 4);
  105. application_.data.application.data = (FLAC__byte*)malloc_or_die_(4);
  106. memcpy(application_.data.application.data, "xf0xe1xd2xc3", 4);
  107. vorbiscomment_.is_last = false;
  108. vorbiscomment_.type = ::FLAC__METADATA_TYPE_VORBIS_COMMENT;
  109. vorbiscomment_.length = (4 + 5) + 4 + (4 + 12) + (4 + 12);
  110. vorbiscomment_.data.vorbis_comment.vendor_string.length = 5;
  111. vorbiscomment_.data.vorbis_comment.vendor_string.entry = (FLAC__byte*)malloc_or_die_(5+1);
  112. memcpy(vorbiscomment_.data.vorbis_comment.vendor_string.entry, "name0", 5+1);
  113. vorbiscomment_.data.vorbis_comment.num_comments = 2;
  114. vorbiscomment_.data.vorbis_comment.comments = (::FLAC__StreamMetadata_VorbisComment_Entry*)malloc_or_die_(vorbiscomment_.data.vorbis_comment.num_comments * sizeof(::FLAC__StreamMetadata_VorbisComment_Entry));
  115. vorbiscomment_.data.vorbis_comment.comments[0].length = 12;
  116. vorbiscomment_.data.vorbis_comment.comments[0].entry = (FLAC__byte*)malloc_or_die_(12+1);
  117. memcpy(vorbiscomment_.data.vorbis_comment.comments[0].entry, "name2=value2", 12+1);
  118. vorbiscomment_.data.vorbis_comment.comments[1].length = 12;
  119. vorbiscomment_.data.vorbis_comment.comments[1].entry = (FLAC__byte*)malloc_or_die_(12+1);
  120. memcpy(vorbiscomment_.data.vorbis_comment.comments[1].entry, "name3=value3", 12+1);
  121. cuesheet_.is_last = true;
  122. cuesheet_.type = ::FLAC__METADATA_TYPE_CUESHEET;
  123. cuesheet_.length =
  124. /* cuesheet guts */
  125. (
  126. FLAC__STREAM_METADATA_CUESHEET_MEDIA_CATALOG_NUMBER_LEN +
  127. FLAC__STREAM_METADATA_CUESHEET_LEAD_IN_LEN +
  128. FLAC__STREAM_METADATA_CUESHEET_IS_CD_LEN +
  129. FLAC__STREAM_METADATA_CUESHEET_RESERVED_LEN +
  130. FLAC__STREAM_METADATA_CUESHEET_NUM_TRACKS_LEN
  131. ) / 8 +
  132. /* 2 tracks */
  133. 2 * (
  134. FLAC__STREAM_METADATA_CUESHEET_TRACK_OFFSET_LEN +
  135. FLAC__STREAM_METADATA_CUESHEET_TRACK_NUMBER_LEN +
  136. FLAC__STREAM_METADATA_CUESHEET_TRACK_ISRC_LEN +
  137. FLAC__STREAM_METADATA_CUESHEET_TRACK_TYPE_LEN +
  138. FLAC__STREAM_METADATA_CUESHEET_TRACK_PRE_EMPHASIS_LEN +
  139. FLAC__STREAM_METADATA_CUESHEET_TRACK_RESERVED_LEN +
  140. FLAC__STREAM_METADATA_CUESHEET_TRACK_NUM_INDICES_LEN
  141. ) / 8 +
  142. /* 3 index points */
  143. 3 * (
  144. FLAC__STREAM_METADATA_CUESHEET_INDEX_OFFSET_LEN +
  145. FLAC__STREAM_METADATA_CUESHEET_INDEX_NUMBER_LEN +
  146. FLAC__STREAM_METADATA_CUESHEET_INDEX_RESERVED_LEN
  147. ) / 8
  148. ;
  149. memset(cuesheet_.data.cue_sheet.media_catalog_number, 0, sizeof(cuesheet_.data.cue_sheet.media_catalog_number));
  150. cuesheet_.data.cue_sheet.media_catalog_number[0] = 'j';
  151. cuesheet_.data.cue_sheet.media_catalog_number[1] = 'C';
  152. cuesheet_.data.cue_sheet.lead_in = 159;
  153. cuesheet_.data.cue_sheet.is_cd = true;
  154. cuesheet_.data.cue_sheet.num_tracks = 2;
  155. cuesheet_.data.cue_sheet.tracks = (FLAC__StreamMetadata_CueSheet_Track*)malloc_or_die_(cuesheet_.data.cue_sheet.num_tracks * sizeof(FLAC__StreamMetadata_CueSheet_Track));
  156. cuesheet_.data.cue_sheet.tracks[0].offset = 1;
  157. cuesheet_.data.cue_sheet.tracks[0].number = 1;
  158. memcpy(cuesheet_.data.cue_sheet.tracks[0].isrc, "ACBDE1234567", sizeof(cuesheet_.data.cue_sheet.tracks[0].isrc));
  159. cuesheet_.data.cue_sheet.tracks[0].type = 0;
  160. cuesheet_.data.cue_sheet.tracks[0].pre_emphasis = 1;
  161. cuesheet_.data.cue_sheet.tracks[0].num_indices = 2;
  162. cuesheet_.data.cue_sheet.tracks[0].indices = (FLAC__StreamMetadata_CueSheet_Index*)malloc_or_die_(cuesheet_.data.cue_sheet.tracks[0].num_indices * sizeof(FLAC__StreamMetadata_CueSheet_Index));
  163. cuesheet_.data.cue_sheet.tracks[0].indices[0].offset = 0;
  164. cuesheet_.data.cue_sheet.tracks[0].indices[0].number = 0;
  165. cuesheet_.data.cue_sheet.tracks[0].indices[1].offset = 1234567890;
  166. cuesheet_.data.cue_sheet.tracks[0].indices[1].number = 1;
  167. cuesheet_.data.cue_sheet.tracks[1].offset = 2345678901u;
  168. cuesheet_.data.cue_sheet.tracks[1].number = 2;
  169. memcpy(cuesheet_.data.cue_sheet.tracks[1].isrc, "ACBDE7654321", sizeof(cuesheet_.data.cue_sheet.tracks[1].isrc));
  170. cuesheet_.data.cue_sheet.tracks[1].type = 1;
  171. cuesheet_.data.cue_sheet.tracks[1].pre_emphasis = 0;
  172. cuesheet_.data.cue_sheet.tracks[1].num_indices = 1;
  173. cuesheet_.data.cue_sheet.tracks[1].indices = (FLAC__StreamMetadata_CueSheet_Index*)malloc_or_die_(cuesheet_.data.cue_sheet.tracks[1].num_indices * sizeof(FLAC__StreamMetadata_CueSheet_Index));
  174. cuesheet_.data.cue_sheet.tracks[1].indices[0].offset = 0;
  175. cuesheet_.data.cue_sheet.tracks[1].indices[0].number = 1;
  176. }
  177. static void free_metadata_blocks_()
  178. {
  179. free(seektable_.data.seek_table.points);
  180. free(application_.data.application.data);
  181. free(vorbiscomment_.data.vorbis_comment.vendor_string.entry);
  182. free(vorbiscomment_.data.vorbis_comment.comments[0].entry);
  183. free(vorbiscomment_.data.vorbis_comment.comments[1].entry);
  184. free(vorbiscomment_.data.vorbis_comment.comments);
  185. free(cuesheet_.data.cue_sheet.tracks[0].indices);
  186. free(cuesheet_.data.cue_sheet.tracks[1].indices);
  187. free(cuesheet_.data.cue_sheet.tracks);
  188. }
  189. bool test_metadata_object_streaminfo()
  190. {
  191. unsigned expected_length;
  192. printf("testing class FLAC::Metadata::StreamInfon");
  193. printf("testing StreamInfo::StreamInfo()... ");
  194. FLAC::Metadata::StreamInfo block;
  195. if(!block.is_valid())
  196. return die_("!block.is_valid()");
  197. expected_length = FLAC__STREAM_METADATA_STREAMINFO_LENGTH;
  198. if(block.get_length() != expected_length) {
  199. printf("FAILED, bad length, expected %u, got %un", expected_length, block.get_length());
  200. return false;
  201. }
  202. printf("OKn");
  203. printf("testing StreamInfo::StreamInfo(const StreamInfo &)... +n");
  204. printf("        StreamInfo::operator!=(const StreamInfo &)... ");
  205. {
  206. FLAC::Metadata::StreamInfo blockcopy(block);
  207. if(!blockcopy.is_valid())
  208. return die_("!block.is_valid()");
  209. if(blockcopy != block)
  210. return die_("copy is not identical to original");
  211. printf("OKn");
  212. printf("testing StreamInfo::~StreamInfo()... ");
  213. }
  214. printf("OKn");
  215. printf("testing StreamInfo::StreamInfo(const ::FLAC__StreamMetadata &)... +n");
  216. printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata &)... ");
  217. {
  218. FLAC::Metadata::StreamInfo blockcopy(streaminfo_);
  219. if(!blockcopy.is_valid())
  220. return die_("!block.is_valid()");
  221. if(blockcopy != streaminfo_)
  222. return die_("copy is not identical to original");
  223. printf("OKn");
  224. }
  225. printf("testing StreamInfo::StreamInfo(const ::FLAC__StreamMetadata *)... +n");
  226. printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
  227. {
  228. FLAC::Metadata::StreamInfo blockcopy(&streaminfo_);
  229. if(!blockcopy.is_valid())
  230. return die_("!block.is_valid()");
  231. if(blockcopy != streaminfo_)
  232. return die_("copy is not identical to original");
  233. printf("OKn");
  234. }
  235. printf("testing StreamInfo::StreamInfo(const ::FLAC__StreamMetadata *, copy=true)... +n");
  236. printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
  237. {
  238. FLAC::Metadata::StreamInfo blockcopy(&streaminfo_, /*copy=*/true);
  239. if(!blockcopy.is_valid())
  240. return die_("!block.is_valid()");
  241. if(blockcopy != streaminfo_)
  242. return die_("copy is not identical to original");
  243. printf("OKn");
  244. }
  245. printf("testing StreamInfo::StreamInfo(const ::FLAC__StreamMetadata *, copy=false)... +n");
  246. printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
  247. {
  248. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&streaminfo_);
  249. FLAC::Metadata::StreamInfo blockcopy(copy, /*copy=*/false);
  250. if(!blockcopy.is_valid())
  251. return die_("!block.is_valid()");
  252. if(blockcopy != streaminfo_)
  253. return die_("copy is not identical to original");
  254. printf("OKn");
  255. }
  256. printf("testing StreamInfo::assign(const ::FLAC__StreamMetadata *, copy=true)... +n");
  257. printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
  258. {
  259. FLAC::Metadata::StreamInfo blockcopy;
  260. blockcopy.assign(&streaminfo_, /*copy=*/true);
  261. if(!blockcopy.is_valid())
  262. return die_("!block.is_valid()");
  263. if(blockcopy != streaminfo_)
  264. return die_("copy is not identical to original");
  265. printf("OKn");
  266. }
  267. printf("testing StreamInfo::assign(const ::FLAC__StreamMetadata *, copy=false)... +n");
  268. printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
  269. {
  270. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&streaminfo_);
  271. FLAC::Metadata::StreamInfo blockcopy;
  272. blockcopy.assign(copy, /*copy=*/false);
  273. if(!blockcopy.is_valid())
  274. return die_("!block.is_valid()");
  275. if(blockcopy != streaminfo_)
  276. return die_("copy is not identical to original");
  277. printf("OKn");
  278. }
  279. printf("testing StreamInfo::operator=(const StreamInfo &)... +n");
  280. printf("        StreamInfo::operator==(const StreamInfo &)... ");
  281. {
  282. FLAC::Metadata::StreamInfo blockcopy = block;
  283. if(!blockcopy.is_valid())
  284. return die_("!block.is_valid()");
  285. if(!(blockcopy == block))
  286. return die_("copy is not identical to original");
  287. printf("OKn");
  288. }
  289. printf("testing StreamInfo::operator=(const ::FLAC__StreamMetadata &)... +n");
  290. printf("        StreamInfo::operator==(const ::FLAC__StreamMetadata &)... ");
  291. {
  292. FLAC::Metadata::StreamInfo blockcopy = streaminfo_;
  293. if(!blockcopy.is_valid())
  294. return die_("!block.is_valid()");
  295. if(!(blockcopy == streaminfo_))
  296. return die_("copy is not identical to original");
  297. printf("OKn");
  298. }
  299. printf("testing StreamInfo::operator=(const ::FLAC__StreamMetadata *)... +n");
  300. printf("        StreamInfo::operator==(const ::FLAC__StreamMetadata *)... ");
  301. {
  302. FLAC::Metadata::StreamInfo blockcopy = &streaminfo_;
  303. if(!blockcopy.is_valid())
  304. return die_("!block.is_valid()");
  305. if(!(blockcopy == streaminfo_))
  306. return die_("copy is not identical to original");
  307. printf("OKn");
  308. }
  309. printf("testing StreamInfo::set_min_blocksize()... ");
  310. block.set_min_blocksize(streaminfo_.data.stream_info.min_blocksize);
  311. printf("OKn");
  312. printf("testing StreamInfo::set_max_blocksize()... ");
  313. block.set_max_blocksize(streaminfo_.data.stream_info.max_blocksize);
  314. printf("OKn");
  315. printf("testing StreamInfo::set_min_framesize()... ");
  316. block.set_min_framesize(streaminfo_.data.stream_info.min_framesize);
  317. printf("OKn");
  318. printf("testing StreamInfo::set_max_framesize()... ");
  319. block.set_max_framesize(streaminfo_.data.stream_info.max_framesize);
  320. printf("OKn");
  321. printf("testing StreamInfo::set_sample_rate()... ");
  322. block.set_sample_rate(streaminfo_.data.stream_info.sample_rate);
  323. printf("OKn");
  324. printf("testing StreamInfo::set_channels()... ");
  325. block.set_channels(streaminfo_.data.stream_info.channels);
  326. printf("OKn");
  327. printf("testing StreamInfo::set_bits_per_sample()... ");
  328. block.set_bits_per_sample(streaminfo_.data.stream_info.bits_per_sample);
  329. printf("OKn");
  330. printf("testing StreamInfo::set_total_samples()... ");
  331. block.set_total_samples(streaminfo_.data.stream_info.total_samples);
  332. printf("OKn");
  333. printf("testing StreamInfo::set_md5sum()... ");
  334. block.set_md5sum(streaminfo_.data.stream_info.md5sum);
  335. printf("OKn");
  336. printf("testing StreamInfo::get_min_blocksize()... ");
  337. if(block.get_min_blocksize() != streaminfo_.data.stream_info.min_blocksize)
  338. return die_("value mismatch, doesn't match previously set value");
  339. printf("OKn");
  340. printf("testing StreamInfo::get_max_blocksize()... ");
  341. if(block.get_max_blocksize() != streaminfo_.data.stream_info.max_blocksize)
  342. return die_("value mismatch, doesn't match previously set value");
  343. printf("OKn");
  344. printf("testing StreamInfo::get_min_framesize()... ");
  345. if(block.get_min_framesize() != streaminfo_.data.stream_info.min_framesize)
  346. return die_("value mismatch, doesn't match previously set value");
  347. printf("OKn");
  348. printf("testing StreamInfo::get_max_framesize()... ");
  349. if(block.get_max_framesize() != streaminfo_.data.stream_info.max_framesize)
  350. return die_("value mismatch, doesn't match previously set value");
  351. printf("OKn");
  352. printf("testing StreamInfo::get_sample_rate()... ");
  353. if(block.get_sample_rate() != streaminfo_.data.stream_info.sample_rate)
  354. return die_("value mismatch, doesn't match previously set value");
  355. printf("OKn");
  356. printf("testing StreamInfo::get_channels()... ");
  357. if(block.get_channels() != streaminfo_.data.stream_info.channels)
  358. return die_("value mismatch, doesn't match previously set value");
  359. printf("OKn");
  360. printf("testing StreamInfo::get_bits_per_sample()... ");
  361. if(block.get_bits_per_sample() != streaminfo_.data.stream_info.bits_per_sample)
  362. return die_("value mismatch, doesn't match previously set value");
  363. printf("OKn");
  364. printf("testing StreamInfo::get_total_samples()... ");
  365. if(block.get_total_samples() != streaminfo_.data.stream_info.total_samples)
  366. return die_("value mismatch, doesn't match previously set value");
  367. printf("OKn");
  368. printf("testing StreamInfo::get_md5sum()... ");
  369. if(0 != memcmp(block.get_md5sum(), streaminfo_.data.stream_info.md5sum, 16))
  370. return die_("value mismatch, doesn't match previously set value");
  371. printf("OKn");
  372. printf("testing FLAC::Metadata::clone(const FLAC::Metadata::Prototype *)... ");
  373. FLAC::Metadata::Prototype *clone_ = FLAC::Metadata::clone(&block);
  374. if(0 == clone_)
  375. return die_("returned NULL");
  376. if(0 == dynamic_cast<FLAC::Metadata::StreamInfo *>(clone_))
  377. return die_("downcast is NULL");
  378. if(*dynamic_cast<FLAC::Metadata::StreamInfo *>(clone_) != block)
  379. return die_("clone is not identical");
  380. printf("OKn");
  381. printf("testing StreamInfo::~StreamInfo()... ");
  382. delete clone_;
  383. printf("OKn");
  384. printf("PASSEDnn");
  385. return true;
  386. }
  387. bool test_metadata_object_padding()
  388. {
  389. unsigned expected_length;
  390. printf("testing class FLAC::Metadata::Paddingn");
  391. printf("testing Padding::Padding()... ");
  392. FLAC::Metadata::Padding block;
  393. if(!block.is_valid())
  394. return die_("!block.is_valid()");
  395. expected_length = 0;
  396. if(block.get_length() != expected_length) {
  397. printf("FAILED, bad length, expected %u, got %un", expected_length, block.get_length());
  398. return false;
  399. }
  400. printf("OKn");
  401. printf("testing Padding::Padding(const Padding &)... +n");
  402. printf("        Padding::operator!=(const Padding &)... ");
  403. {
  404. FLAC::Metadata::Padding blockcopy(block);
  405. if(!blockcopy.is_valid())
  406. return die_("!block.is_valid()");
  407. if(blockcopy != block)
  408. return die_("copy is not identical to original");
  409. printf("OKn");
  410. printf("testing Padding::~Padding()... ");
  411. }
  412. printf("OKn");
  413. printf("testing Padding::Padding(const ::FLAC__StreamMetadata &)... +n");
  414. printf("        Padding::operator!=(const ::FLAC__StreamMetadata &)... ");
  415. {
  416. FLAC::Metadata::Padding blockcopy(padding_);
  417. if(!blockcopy.is_valid())
  418. return die_("!block.is_valid()");
  419. if(blockcopy != padding_)
  420. return die_("copy is not identical to original");
  421. printf("OKn");
  422. }
  423. printf("testing Padding::Padding(const ::FLAC__StreamMetadata *)... +n");
  424. printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
  425. {
  426. FLAC::Metadata::Padding blockcopy(&padding_);
  427. if(!blockcopy.is_valid())
  428. return die_("!block.is_valid()");
  429. if(blockcopy != padding_)
  430. return die_("copy is not identical to original");
  431. printf("OKn");
  432. }
  433. printf("testing Padding::Padding(const ::FLAC__StreamMetadata *, copy=true)... +n");
  434. printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
  435. {
  436. FLAC::Metadata::Padding blockcopy(&padding_, /*copy=*/true);
  437. if(!blockcopy.is_valid())
  438. return die_("!block.is_valid()");
  439. if(blockcopy != padding_)
  440. return die_("copy is not identical to original");
  441. printf("OKn");
  442. }
  443. printf("testing Padding::Padding(const ::FLAC__StreamMetadata *, copy=false)... +n");
  444. printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
  445. {
  446. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&padding_);
  447. FLAC::Metadata::Padding blockcopy(copy, /*copy=*/false);
  448. if(!blockcopy.is_valid())
  449. return die_("!block.is_valid()");
  450. if(blockcopy != padding_)
  451. return die_("copy is not identical to original");
  452. printf("OKn");
  453. }
  454. printf("testing Padding::assign(const ::FLAC__StreamMetadata *, copy=true)... +n");
  455. printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
  456. {
  457. FLAC::Metadata::Padding blockcopy;
  458. blockcopy.assign(&padding_, /*copy=*/true);
  459. if(!blockcopy.is_valid())
  460. return die_("!block.is_valid()");
  461. if(blockcopy != padding_)
  462. return die_("copy is not identical to original");
  463. printf("OKn");
  464. }
  465. printf("testing Padding::assign(const ::FLAC__StreamMetadata *, copy=false)... +n");
  466. printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
  467. {
  468. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&padding_);
  469. FLAC::Metadata::Padding blockcopy;
  470. blockcopy.assign(copy, /*copy=*/false);
  471. if(!blockcopy.is_valid())
  472. return die_("!block.is_valid()");
  473. if(blockcopy != padding_)
  474. return die_("copy is not identical to original");
  475. printf("OKn");
  476. }
  477. printf("testing Padding::operator=(const Padding &)... +n");
  478. printf("        Padding::operator==(const Padding &)... ");
  479. {
  480. FLAC::Metadata::Padding blockcopy = block;
  481. if(!blockcopy.is_valid())
  482. return die_("!block.is_valid()");
  483. if(!(blockcopy == block))
  484. return die_("copy is not identical to original");
  485. printf("OKn");
  486. }
  487. printf("testing Padding::operator=(const ::FLAC__StreamMetadata &)... +n");
  488. printf("        Padding::operator==(const ::FLAC__StreamMetadata &)... ");
  489. {
  490. FLAC::Metadata::Padding blockcopy = padding_;
  491. if(!blockcopy.is_valid())
  492. return die_("!block.is_valid()");
  493. if(!(blockcopy == padding_))
  494. return die_("copy is not identical to original");
  495. printf("OKn");
  496. }
  497. printf("testing Padding::operator=(const ::FLAC__StreamMetadata *)... +n");
  498. printf("        Padding::operator==(const ::FLAC__StreamMetadata *)... ");
  499. {
  500. FLAC::Metadata::Padding blockcopy = &padding_;
  501. if(!blockcopy.is_valid())
  502. return die_("!block.is_valid()");
  503. if(!(blockcopy == padding_))
  504. return die_("copy is not identical to original");
  505. printf("OKn");
  506. }
  507. printf("testing Padding::set_length()... ");
  508. block.set_length(padding_.length);
  509. printf("OKn");
  510. printf("testing Prototype::get_length()... ");
  511. if(block.get_length() != padding_.length)
  512. return die_("value mismatch, doesn't match previously set value");
  513. printf("OKn");
  514. printf("testing FLAC::Metadata::clone(const FLAC::Metadata::Prototype *)... ");
  515. FLAC::Metadata::Prototype *clone_ = FLAC::Metadata::clone(&block);
  516. if(0 == clone_)
  517. return die_("returned NULL");
  518. if(0 == dynamic_cast<FLAC::Metadata::Padding *>(clone_))
  519. return die_("downcast is NULL");
  520. if(*dynamic_cast<FLAC::Metadata::Padding *>(clone_) != block)
  521. return die_("clone is not identical");
  522. printf("OKn");
  523. printf("testing Padding::~Padding()... ");
  524. delete clone_;
  525. printf("OKn");
  526. printf("PASSEDnn");
  527. return true;
  528. }
  529. bool test_metadata_object_application()
  530. {
  531. unsigned expected_length;
  532. printf("testing class FLAC::Metadata::Applicationn");
  533. printf("testing Application::Application()... ");
  534. FLAC::Metadata::Application block;
  535. if(!block.is_valid())
  536. return die_("!block.is_valid()");
  537. expected_length = FLAC__STREAM_METADATA_APPLICATION_ID_LEN / 8;
  538. if(block.get_length() != expected_length) {
  539. printf("FAILED, bad length, expected %u, got %un", expected_length, block.get_length());
  540. return false;
  541. }
  542. printf("OKn");
  543. printf("testing Application::Application(const Application &)... +n");
  544. printf("        Application::operator!=(const Application &)... ");
  545. {
  546. FLAC::Metadata::Application blockcopy(block);
  547. if(!blockcopy.is_valid())
  548. return die_("!block.is_valid()");
  549. if(blockcopy != block)
  550. return die_("copy is not identical to original");
  551. printf("OKn");
  552. printf("testing Application::~Application()... ");
  553. }
  554. printf("OKn");
  555. printf("testing Application::Application(const ::FLAC__StreamMetadata &)... +n");
  556. printf("        Application::operator!=(const ::FLAC__StreamMetadata &)... ");
  557. {
  558. FLAC::Metadata::Application blockcopy(application_);
  559. if(!blockcopy.is_valid())
  560. return die_("!block.is_valid()");
  561. if(blockcopy != application_)
  562. return die_("copy is not identical to original");
  563. printf("OKn");
  564. }
  565. printf("testing Application::Application(const ::FLAC__StreamMetadata *)... +n");
  566. printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
  567. {
  568. FLAC::Metadata::Application blockcopy(&application_);
  569. if(!blockcopy.is_valid())
  570. return die_("!block.is_valid()");
  571. if(blockcopy != application_)
  572. return die_("copy is not identical to original");
  573. printf("OKn");
  574. }
  575. printf("testing Application::Application(const ::FLAC__StreamMetadata *, copy=true)... +n");
  576. printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
  577. {
  578. FLAC::Metadata::Application blockcopy(&application_, /*copy=*/true);
  579. if(!blockcopy.is_valid())
  580. return die_("!block.is_valid()");
  581. if(blockcopy != application_)
  582. return die_("copy is not identical to original");
  583. printf("OKn");
  584. }
  585. printf("testing Application::Application(const ::FLAC__StreamMetadata *, copy=false)... +n");
  586. printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
  587. {
  588. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&application_);
  589. FLAC::Metadata::Application blockcopy(copy, /*copy=*/false);
  590. if(!blockcopy.is_valid())
  591. return die_("!block.is_valid()");
  592. if(blockcopy != application_)
  593. return die_("copy is not identical to original");
  594. printf("OKn");
  595. }
  596. printf("testing Application::assign(const ::FLAC__StreamMetadata *, copy=true)... +n");
  597. printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
  598. {
  599. FLAC::Metadata::Application blockcopy;
  600. blockcopy.assign(&application_, /*copy=*/true);
  601. if(!blockcopy.is_valid())
  602. return die_("!block.is_valid()");
  603. if(blockcopy != application_)
  604. return die_("copy is not identical to original");
  605. printf("OKn");
  606. }
  607. printf("testing Application::assign(const ::FLAC__StreamMetadata *, copy=false)... +n");
  608. printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
  609. {
  610. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&application_);
  611. FLAC::Metadata::Application blockcopy;
  612. blockcopy.assign(copy, /*copy=*/false);
  613. if(!blockcopy.is_valid())
  614. return die_("!block.is_valid()");
  615. if(blockcopy != application_)
  616. return die_("copy is not identical to original");
  617. printf("OKn");
  618. }
  619. printf("testing Application::operator=(const Application &)... +n");
  620. printf("        Application::operator==(const Application &)... ");
  621. {
  622. FLAC::Metadata::Application blockcopy = block;
  623. if(!blockcopy.is_valid())
  624. return die_("!block.is_valid()");
  625. if(!(blockcopy == block))
  626. return die_("copy is not identical to original");
  627. printf("OKn");
  628. }
  629. printf("testing Application::operator=(const ::FLAC__StreamMetadata &)... +n");
  630. printf("        Application::operator==(const ::FLAC__StreamMetadata &)... ");
  631. {
  632. FLAC::Metadata::Application blockcopy = application_;
  633. if(!blockcopy.is_valid())
  634. return die_("!block.is_valid()");
  635. if(!(blockcopy == application_))
  636. return die_("copy is not identical to original");
  637. printf("OKn");
  638. }
  639. printf("testing Application::operator=(const ::FLAC__StreamMetadata *)... +n");
  640. printf("        Application::operator==(const ::FLAC__StreamMetadata *)... ");
  641. {
  642. FLAC::Metadata::Application blockcopy = &application_;
  643. if(!blockcopy.is_valid())
  644. return die_("!block.is_valid()");
  645. if(!(blockcopy == application_))
  646. return die_("copy is not identical to original");
  647. printf("OKn");
  648. }
  649. printf("testing Application::set_id()... ");
  650. block.set_id(application_.data.application.id);
  651. printf("OKn");
  652. printf("testing Application::set_data()... ");
  653. block.set_data(application_.data.application.data, application_.length - sizeof(application_.data.application.id), /*copy=*/true);
  654. printf("OKn");
  655. printf("testing Application::get_id()... ");
  656. if(0 != memcmp(block.get_id(), application_.data.application.id, sizeof(application_.data.application.id)))
  657. return die_("value mismatch, doesn't match previously set value");
  658. printf("OKn");
  659. printf("testing Application::get_data()... ");
  660. if(0 != memcmp(block.get_data(), application_.data.application.data, application_.length - sizeof(application_.data.application.id)))
  661. return die_("value mismatch, doesn't match previously set value");
  662. printf("OKn");
  663. printf("testing FLAC::Metadata::clone(const FLAC::Metadata::Prototype *)... ");
  664. FLAC::Metadata::Prototype *clone_ = FLAC::Metadata::clone(&block);
  665. if(0 == clone_)
  666. return die_("returned NULL");
  667. if(0 == dynamic_cast<FLAC::Metadata::Application *>(clone_))
  668. return die_("downcast is NULL");
  669. if(*dynamic_cast<FLAC::Metadata::Application *>(clone_) != block)
  670. return die_("clone is not identical");
  671. printf("OKn");
  672. printf("testing Application::~Application()... ");
  673. delete clone_;
  674. printf("OKn");
  675. printf("PASSEDnn");
  676. return true;
  677. }
  678. bool test_metadata_object_seektable()
  679. {
  680. unsigned expected_length;
  681. printf("testing class FLAC::Metadata::SeekTablen");
  682. printf("testing SeekTable::SeekTable()... ");
  683. FLAC::Metadata::SeekTable block;
  684. if(!block.is_valid())
  685. return die_("!block.is_valid()");
  686. expected_length = 0;
  687. if(block.get_length() != expected_length) {
  688. printf("FAILED, bad length, expected %u, got %un", expected_length, block.get_length());
  689. return false;
  690. }
  691. printf("OKn");
  692. printf("testing SeekTable::SeekTable(const SeekTable &)... +n");
  693. printf("        SeekTable::operator!=(const SeekTable &)... ");
  694. {
  695. FLAC::Metadata::SeekTable blockcopy(block);
  696. if(!blockcopy.is_valid())
  697. return die_("!block.is_valid()");
  698. if(blockcopy != block)
  699. return die_("copy is not identical to original");
  700. printf("OKn");
  701. printf("testing SeekTable::~SeekTable()... ");
  702. }
  703. printf("OKn");
  704. printf("testing SeekTable::SeekTable(const ::FLAC__StreamMetadata &)... +n");
  705. printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata &)... ");
  706. {
  707. FLAC::Metadata::SeekTable blockcopy(seektable_);
  708. if(!blockcopy.is_valid())
  709. return die_("!block.is_valid()");
  710. if(blockcopy != seektable_)
  711. return die_("copy is not identical to original");
  712. printf("OKn");
  713. }
  714. printf("testing SeekTable::SeekTable(const ::FLAC__StreamMetadata *)... +n");
  715. printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
  716. {
  717. FLAC::Metadata::SeekTable blockcopy(&seektable_);
  718. if(!blockcopy.is_valid())
  719. return die_("!block.is_valid()");
  720. if(blockcopy != seektable_)
  721. return die_("copy is not identical to original");
  722. printf("OKn");
  723. }
  724. printf("testing SeekTable::SeekTable(const ::FLAC__StreamMetadata *, copy=true)... +n");
  725. printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
  726. {
  727. FLAC::Metadata::SeekTable blockcopy(&seektable_, /*copy=*/true);
  728. if(!blockcopy.is_valid())
  729. return die_("!block.is_valid()");
  730. if(blockcopy != seektable_)
  731. return die_("copy is not identical to original");
  732. printf("OKn");
  733. }
  734. printf("testing SeekTable::SeekTable(const ::FLAC__StreamMetadata *, copy=false)... +n");
  735. printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
  736. {
  737. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&seektable_);
  738. FLAC::Metadata::SeekTable blockcopy(copy, /*copy=*/false);
  739. if(!blockcopy.is_valid())
  740. return die_("!block.is_valid()");
  741. if(blockcopy != seektable_)
  742. return die_("copy is not identical to original");
  743. printf("OKn");
  744. }
  745. printf("testing SeekTable::assign(const ::FLAC__StreamMetadata *, copy=true)... +n");
  746. printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
  747. {
  748. FLAC::Metadata::SeekTable blockcopy;
  749. blockcopy.assign(&seektable_, /*copy=*/true);
  750. if(!blockcopy.is_valid())
  751. return die_("!block.is_valid()");
  752. if(blockcopy != seektable_)
  753. return die_("copy is not identical to original");
  754. printf("OKn");
  755. }
  756. printf("testing SeekTable::assign(const ::FLAC__StreamMetadata *, copy=false)... +n");
  757. printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
  758. {
  759. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&seektable_);
  760. FLAC::Metadata::SeekTable blockcopy;
  761. blockcopy.assign(copy, /*copy=*/false);
  762. if(!blockcopy.is_valid())
  763. return die_("!block.is_valid()");
  764. if(blockcopy != seektable_)
  765. return die_("copy is not identical to original");
  766. printf("OKn");
  767. }
  768. printf("testing SeekTable::operator=(const SeekTable &)... +n");
  769. printf("        SeekTable::operator==(const SeekTable &)... ");
  770. {
  771. FLAC::Metadata::SeekTable blockcopy = block;
  772. if(!blockcopy.is_valid())
  773. return die_("!block.is_valid()");
  774. if(!(blockcopy == block))
  775. return die_("copy is not identical to original");
  776. printf("OKn");
  777. }
  778. printf("testing SeekTable::operator=(const ::FLAC__StreamMetadata &)... +n");
  779. printf("        SeekTable::operator==(const ::FLAC__StreamMetadata &)... ");
  780. {
  781. FLAC::Metadata::SeekTable blockcopy = seektable_;
  782. if(!blockcopy.is_valid())
  783. return die_("!block.is_valid()");
  784. if(!(blockcopy == seektable_))
  785. return die_("copy is not identical to original");
  786. printf("OKn");
  787. }
  788. printf("testing SeekTable::operator=(const ::FLAC__StreamMetadata *)... +n");
  789. printf("        SeekTable::operator==(const ::FLAC__StreamMetadata *)... ");
  790. {
  791. FLAC::Metadata::SeekTable blockcopy = &seektable_;
  792. if(!blockcopy.is_valid())
  793. return die_("!block.is_valid()");
  794. if(!(blockcopy == seektable_))
  795. return die_("copy is not identical to original");
  796. printf("OKn");
  797. }
  798. printf("testing SeekTable::insert_point() x 3... ");
  799. if(!block.insert_point(0, seektable_.data.seek_table.points[1]))
  800. return die_("returned false");
  801. if(!block.insert_point(0, seektable_.data.seek_table.points[1]))
  802. return die_("returned false");
  803. if(!block.insert_point(1, seektable_.data.seek_table.points[0]))
  804. return die_("returned false");
  805. printf("OKn");
  806. printf("testing SeekTable::is_legal()... ");
  807. if(block.is_legal())
  808. return die_("returned true");
  809. printf("OKn");
  810. printf("testing SeekTable::set_point()... ");
  811. block.set_point(0, seektable_.data.seek_table.points[0]);
  812. printf("OKn");
  813. printf("testing SeekTable::delete_point()... ");
  814. if(!block.delete_point(0))
  815. return die_("returned false");
  816. printf("OKn");
  817. printf("testing SeekTable::is_legal()... ");
  818. if(!block.is_legal())
  819. return die_("returned false");
  820. printf("OKn");
  821. printf("testing SeekTable::get_num_points()... ");
  822. if(block.get_num_points() != seektable_.data.seek_table.num_points)
  823. return die_("number mismatch");
  824. printf("OKn");
  825. printf("testing SeekTable::operator!=(const ::FLAC__StreamMetadata &)... ");
  826. if(block != seektable_)
  827. return die_("data mismatch");
  828. printf("OKn");
  829. printf("testing SeekTable::get_point()... ");
  830. if(
  831. block.get_point(1).sample_number != seektable_.data.seek_table.points[1].sample_number ||
  832. block.get_point(1).stream_offset != seektable_.data.seek_table.points[1].stream_offset ||
  833. block.get_point(1).frame_samples != seektable_.data.seek_table.points[1].frame_samples
  834. )
  835. return die_("point mismatch");
  836. printf("OKn");
  837. printf("testing FLAC::Metadata::clone(const FLAC::Metadata::Prototype *)... ");
  838. FLAC::Metadata::Prototype *clone_ = FLAC::Metadata::clone(&block);
  839. if(0 == clone_)
  840. return die_("returned NULL");
  841. if(0 == dynamic_cast<FLAC::Metadata::SeekTable *>(clone_))
  842. return die_("downcast is NULL");
  843. if(*dynamic_cast<FLAC::Metadata::SeekTable *>(clone_) != block)
  844. return die_("clone is not identical");
  845. printf("OKn");
  846. printf("testing SeekTable::~SeekTable()... ");
  847. delete clone_;
  848. printf("OKn");
  849. printf("PASSEDnn");
  850. return true;
  851. }
  852. bool test_metadata_object_vorbiscomment()
  853. {
  854. unsigned expected_length;
  855. printf("testing class FLAC::Metadata::VorbisComment::Entryn");
  856. printf("testing Entry::Entry()... ");
  857. {
  858. FLAC::Metadata::VorbisComment::Entry entry1;
  859. if(!entry1.is_valid())
  860. return die_("!is_valid()");
  861. printf("OKn");
  862. printf("testing Entry::~Entry()... ");
  863. }
  864. printf("OKn");
  865. printf("testing Entry::Entry(const char *field, unsigned field_length)... ");
  866. FLAC::Metadata::VorbisComment::Entry entry2("name2=value2", strlen("name2=value2"));
  867. if(!entry2.is_valid())
  868. return die_("!is_valid()");
  869. printf("OKn");
  870. {
  871. printf("testing Entry::Entry(const char *field)... ");
  872. FLAC::Metadata::VorbisComment::Entry entry2z("name2=value2");
  873. if(!entry2z.is_valid())
  874. return die_("!is_valid()");
  875. if(strcmp(entry2.get_field(), entry2z.get_field()))
  876. return die_("bad value");
  877. printf("OKn");
  878. }
  879. printf("testing Entry::Entry(const char *field_name, const char *field_value, unsigned field_value_length)... ");
  880. FLAC::Metadata::VorbisComment::Entry entry3("name3", "value3", strlen("value3"));
  881. if(!entry3.is_valid())
  882. return die_("!is_valid()");
  883. printf("OKn");
  884. {
  885. printf("testing Entry::Entry(const char *field_name, const char *field_value)... ");
  886. FLAC::Metadata::VorbisComment::Entry entry3z("name3", "value3");
  887. if(!entry3z.is_valid())
  888. return die_("!is_valid()");
  889. if(strcmp(entry3.get_field(), entry3z.get_field()))
  890. return die_("bad value");
  891. printf("OKn");
  892. }
  893. printf("testing Entry::Entry(const Entry &entry)... ");
  894. {
  895. FLAC::Metadata::VorbisComment::Entry entry2copy(entry2);
  896. if(!entry2copy.is_valid())
  897. return die_("!is_valid()");
  898. printf("OKn");
  899. printf("testing Entry::~Entry()... ");
  900. }
  901. printf("OKn");
  902. printf("testing Entry::operator=(const Entry &entry)... ");
  903. FLAC::Metadata::VorbisComment::Entry entry1 = entry2;
  904. if(!entry2.is_valid())
  905. return die_("!is_valid()");
  906. printf("OKn");
  907. printf("testing Entry::get_field_length()... ");
  908. if(entry1.get_field_length() != strlen("name2=value2"))
  909. return die_("value mismatch");
  910. printf("OKn");
  911. printf("testing Entry::get_field_name_length()... ");
  912. if(entry1.get_field_name_length() != strlen("name2"))
  913. return die_("value mismatch");
  914. printf("OKn");
  915. printf("testing Entry::get_field_value_length()... ");
  916. if(entry1.get_field_value_length() != strlen("value2"))
  917. return die_("value mismatch");
  918. printf("OKn");
  919. printf("testing Entry::get_entry()... ");
  920. {
  921. ::FLAC__StreamMetadata_VorbisComment_Entry entry = entry1.get_entry();
  922. if(entry.length != strlen("name2=value2"))
  923. return die_("entry length mismatch");
  924. if(0 != memcmp(entry.entry, "name2=value2", entry.length))
  925. return die_("entry value mismatch");
  926. }
  927. printf("OKn");
  928. printf("testing Entry::get_field()... ");
  929. if(0 != memcmp(entry1.get_field(), "name2=value2", strlen("name2=value2")))
  930. return die_("value mismatch");
  931. printf("OKn");
  932. printf("testing Entry::get_field_name()... ");
  933. if(0 != memcmp(entry1.get_field_name(), "name2", strlen("name2")))
  934. return die_("value mismatch");
  935. printf("OKn");
  936. printf("testing Entry::get_field_value()... ");
  937. if(0 != memcmp(entry1.get_field_value(), "value2", strlen("value2")))
  938. return die_("value mismatch");
  939. printf("OKn");
  940. printf("testing Entry::set_field_name()... ");
  941. if(!entry1.set_field_name("name1"))
  942. return die_("returned false");
  943. if(0 != memcmp(entry1.get_field_name(), "name1", strlen("name1")))
  944. return die_("value mismatch");
  945. if(0 != memcmp(entry1.get_field(), "name1=value2", strlen("name1=value2")))
  946. return die_("entry mismatch");
  947. printf("OKn");
  948. printf("testing Entry::set_field_value(const char *field_value, unsigned field_value_length)... ");
  949. if(!entry1.set_field_value("value1", strlen("value1")))
  950. return die_("returned false");
  951. if(0 != memcmp(entry1.get_field_value(), "value1", strlen("value1")))
  952. return die_("value mismatch");
  953. if(0 != memcmp(entry1.get_field(), "name1=value1", strlen("name1=value1")))
  954. return die_("entry mismatch");
  955. printf("OKn");
  956. printf("testing Entry::set_field_value(const char *field_value)... ");
  957. if(!entry1.set_field_value("value1"))
  958. return die_("returned false");
  959. if(0 != memcmp(entry1.get_field_value(), "value1", strlen("value1")))
  960. return die_("value mismatch");
  961. if(0 != memcmp(entry1.get_field(), "name1=value1", strlen("name1=value1")))
  962. return die_("entry mismatch");
  963. printf("OKn");
  964. printf("testing Entry::set_field(const char *field, unsigned field_length)... ");
  965. if(!entry1.set_field("name0=value0", strlen("name0=value0")))
  966. return die_("returned false");
  967. if(0 != memcmp(entry1.get_field_name(), "name0", strlen("name0")))
  968. return die_("value mismatch");
  969. if(0 != memcmp(entry1.get_field_value(), "value0", strlen("value0")))
  970. return die_("value mismatch");
  971. if(0 != memcmp(entry1.get_field(), "name0=value0", strlen("name0=value0")))
  972. return die_("entry mismatch");
  973. printf("OKn");
  974. printf("testing Entry::set_field(const char *field)... ");
  975. if(!entry1.set_field("name0=value0"))
  976. return die_("returned false");
  977. if(0 != memcmp(entry1.get_field_name(), "name0", strlen("name0")))
  978. return die_("value mismatch");
  979. if(0 != memcmp(entry1.get_field_value(), "value0", strlen("value0")))
  980. return die_("value mismatch");
  981. if(0 != memcmp(entry1.get_field(), "name0=value0", strlen("name0=value0")))
  982. return die_("entry mismatch");
  983. printf("OKn");
  984. printf("PASSEDnn");
  985. printf("testing class FLAC::Metadata::VorbisCommentn");
  986. printf("testing VorbisComment::VorbisComment()... ");
  987. FLAC::Metadata::VorbisComment block;
  988. if(!block.is_valid())
  989. return die_("!block.is_valid()");
  990. expected_length = (FLAC__STREAM_METADATA_VORBIS_COMMENT_ENTRY_LENGTH_LEN/8 + strlen(::FLAC__VENDOR_STRING) + FLAC__STREAM_METADATA_VORBIS_COMMENT_NUM_COMMENTS_LEN/8);
  991. if(block.get_length() != expected_length) {
  992. printf("FAILED, bad length, expected %u, got %un", expected_length, block.get_length());
  993. return false;
  994. }
  995. printf("OKn");
  996. printf("testing VorbisComment::VorbisComment(const VorbisComment &)... +n");
  997. printf("        VorbisComment::operator!=(const VorbisComment &)... ");
  998. {
  999. FLAC::Metadata::VorbisComment blockcopy(block);
  1000. if(!blockcopy.is_valid())
  1001. return die_("!block.is_valid()");
  1002. if(blockcopy != block)
  1003. return die_("copy is not identical to original");
  1004. printf("OKn");
  1005. printf("testing VorbisComment::~VorbisComment()... ");
  1006. }
  1007. printf("OKn");
  1008. printf("testing VorbisComment::VorbisComment(const ::FLAC__StreamMetadata &)... +n");
  1009. printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata &)... ");
  1010. {
  1011. FLAC::Metadata::VorbisComment blockcopy(vorbiscomment_);
  1012. if(!blockcopy.is_valid())
  1013. return die_("!block.is_valid()");
  1014. if(blockcopy != vorbiscomment_)
  1015. return die_("copy is not identical to original");
  1016. printf("OKn");
  1017. }
  1018. printf("testing VorbisComment::VorbisComment(const ::FLAC__StreamMetadata *)... +n");
  1019. printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
  1020. {
  1021. FLAC::Metadata::VorbisComment blockcopy(&vorbiscomment_);
  1022. if(!blockcopy.is_valid())
  1023. return die_("!block.is_valid()");
  1024. if(blockcopy != vorbiscomment_)
  1025. return die_("copy is not identical to original");
  1026. printf("OKn");
  1027. }
  1028. printf("testing VorbisComment::VorbisComment(const ::FLAC__StreamMetadata *, copy=true)... +n");
  1029. printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
  1030. {
  1031. FLAC::Metadata::VorbisComment blockcopy(&vorbiscomment_, /*copy=*/true);
  1032. if(!blockcopy.is_valid())
  1033. return die_("!block.is_valid()");
  1034. if(blockcopy != vorbiscomment_)
  1035. return die_("copy is not identical to original");
  1036. printf("OKn");
  1037. }
  1038. printf("testing VorbisComment::VorbisComment(const ::FLAC__StreamMetadata *, copy=false)... +n");
  1039. printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
  1040. {
  1041. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&vorbiscomment_);
  1042. FLAC::Metadata::VorbisComment blockcopy(copy, /*copy=*/false);
  1043. if(!blockcopy.is_valid())
  1044. return die_("!block.is_valid()");
  1045. if(blockcopy != vorbiscomment_)
  1046. return die_("copy is not identical to original");
  1047. printf("OKn");
  1048. }
  1049. printf("testing VorbisComment::assign(const ::FLAC__StreamMetadata *, copy=true)... +n");
  1050. printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
  1051. {
  1052. FLAC::Metadata::VorbisComment blockcopy;
  1053. blockcopy.assign(&vorbiscomment_, /*copy=*/true);
  1054. if(!blockcopy.is_valid())
  1055. return die_("!block.is_valid()");
  1056. if(blockcopy != vorbiscomment_)
  1057. return die_("copy is not identical to original");
  1058. printf("OKn");
  1059. }
  1060. printf("testing VorbisComment::assign(const ::FLAC__StreamMetadata *, copy=false)... +n");
  1061. printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
  1062. {
  1063. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&vorbiscomment_);
  1064. FLAC::Metadata::VorbisComment blockcopy;
  1065. blockcopy.assign(copy, /*copy=*/false);
  1066. if(!blockcopy.is_valid())
  1067. return die_("!block.is_valid()");
  1068. if(blockcopy != vorbiscomment_)
  1069. return die_("copy is not identical to original");
  1070. printf("OKn");
  1071. }
  1072. printf("testing VorbisComment::operator=(const VorbisComment &)... +n");
  1073. printf("        VorbisComment::operator==(const VorbisComment &)... ");
  1074. {
  1075. FLAC::Metadata::VorbisComment blockcopy = block;
  1076. if(!blockcopy.is_valid())
  1077. return die_("!block.is_valid()");
  1078. if(!(blockcopy == block))
  1079. return die_("copy is not identical to original");
  1080. printf("OKn");
  1081. }
  1082. printf("testing VorbisComment::operator=(const ::FLAC__StreamMetadata &)... +n");
  1083. printf("        VorbisComment::operator==(const ::FLAC__StreamMetadata &)... ");
  1084. {
  1085. FLAC::Metadata::VorbisComment blockcopy = vorbiscomment_;
  1086. if(!blockcopy.is_valid())
  1087. return die_("!block.is_valid()");
  1088. if(!(blockcopy == vorbiscomment_))
  1089. return die_("copy is not identical to original");
  1090. printf("OKn");
  1091. }
  1092. printf("testing VorbisComment::operator=(const ::FLAC__StreamMetadata *)... +n");
  1093. printf("        VorbisComment::operator==(const ::FLAC__StreamMetadata *)... ");
  1094. {
  1095. FLAC::Metadata::VorbisComment blockcopy = &vorbiscomment_;
  1096. if(!blockcopy.is_valid())
  1097. return die_("!block.is_valid()");
  1098. if(!(blockcopy == vorbiscomment_))
  1099. return die_("copy is not identical to original");
  1100. printf("OKn");
  1101. }
  1102. printf("testing VorbisComment::get_num_comments()... ");
  1103. if(block.get_num_comments() != 0)
  1104. return die_("value mismatch, expected 0");
  1105. printf("OKn");
  1106. printf("testing VorbisComment::set_vendor_string()... ");
  1107. if(!block.set_vendor_string((const FLAC__byte *)"mame0"))
  1108. return die_("returned false");
  1109. printf("OKn");
  1110. vorbiscomment_.data.vorbis_comment.vendor_string.entry[0] = 'm';
  1111. printf("testing VorbisComment::get_vendor_string()... ");
  1112. if(strlen((const char *)block.get_vendor_string()) != vorbiscomment_.data.vorbis_comment.vendor_string.length)
  1113. return die_("length mismatch");
  1114. if(0 != memcmp(block.get_vendor_string(), vorbiscomment_.data.vorbis_comment.vendor_string.entry, vorbiscomment_.data.vorbis_comment.vendor_string.length))
  1115. return die_("value mismatch");
  1116. printf("OKn");
  1117. printf("testing VorbisComment::append_comment()... +n");
  1118. printf("        VorbisComment::get_comment()... ");
  1119. if(!block.append_comment(entry3))
  1120. return die_("returned false");
  1121. if(block.get_comment(0).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[1].length)
  1122. return die_("length mismatch");
  1123. if(0 != memcmp(block.get_comment(0).get_field(), vorbiscomment_.data.vorbis_comment.comments[1].entry, vorbiscomment_.data.vorbis_comment.comments[1].length))
  1124. return die_("value mismatch");
  1125. printf("OKn");
  1126. printf("testing VorbisComment::append_comment()... +n");
  1127. printf("        VorbisComment::get_comment()... ");
  1128. if(!block.append_comment(entry2))
  1129. return die_("returned false");
  1130. if(block.get_comment(1).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[0].length)
  1131. return die_("length mismatch");
  1132. if(0 != memcmp(block.get_comment(1).get_field(), vorbiscomment_.data.vorbis_comment.comments[0].entry, vorbiscomment_.data.vorbis_comment.comments[0].length))
  1133. return die_("value mismatch");
  1134. printf("OKn");
  1135. printf("testing VorbisComment::delete_comment()... +n");
  1136. printf("        VorbisComment::get_comment()... ");
  1137. if(!block.delete_comment(0))
  1138. return die_("returned false");
  1139. if(block.get_comment(0).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[0].length)
  1140. return die_("length[0] mismatch");
  1141. if(0 != memcmp(block.get_comment(0).get_field(), vorbiscomment_.data.vorbis_comment.comments[0].entry, vorbiscomment_.data.vorbis_comment.comments[0].length))
  1142. return die_("value[0] mismatch");
  1143. printf("OKn");
  1144. printf("testing VorbisComment::delete_comment()... +n");
  1145. printf("        VorbisComment::get_comment()... ");
  1146. if(!block.delete_comment(0))
  1147. return die_("returned false");
  1148. if(block.get_num_comments() != 0)
  1149. return die_("block mismatch, expected num_comments = 0");
  1150. printf("OKn");
  1151. printf("testing VorbisComment::insert_comment()... +n");
  1152. printf("        VorbisComment::get_comment()... ");
  1153. if(!block.insert_comment(0, entry3))
  1154. return die_("returned false");
  1155. if(block.get_comment(0).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[1].length)
  1156. return die_("length mismatch");
  1157. if(0 != memcmp(block.get_comment(0).get_field(), vorbiscomment_.data.vorbis_comment.comments[1].entry, vorbiscomment_.data.vorbis_comment.comments[1].length))
  1158. return die_("value mismatch");
  1159. printf("OKn");
  1160. printf("testing VorbisComment::insert_comment()... +n");
  1161. printf("        VorbisComment::get_comment()... ");
  1162. if(!block.insert_comment(0, entry3))
  1163. return die_("returned false");
  1164. if(block.get_comment(0).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[1].length)
  1165. return die_("length mismatch");
  1166. if(0 != memcmp(block.get_comment(0).get_field(), vorbiscomment_.data.vorbis_comment.comments[1].entry, vorbiscomment_.data.vorbis_comment.comments[1].length))
  1167. return die_("value mismatch");
  1168. printf("OKn");
  1169. printf("testing VorbisComment::insert_comment()... +n");
  1170. printf("        VorbisComment::get_comment()... ");
  1171. if(!block.insert_comment(1, entry2))
  1172. return die_("returned false");
  1173. if(block.get_comment(1).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[0].length)
  1174. return die_("length mismatch");
  1175. if(0 != memcmp(block.get_comment(1).get_field(), vorbiscomment_.data.vorbis_comment.comments[0].entry, vorbiscomment_.data.vorbis_comment.comments[0].length))
  1176. return die_("value mismatch");
  1177. printf("OKn");
  1178. printf("testing VorbisComment::set_comment()... +n");
  1179. printf("        VorbisComment::get_comment()... ");
  1180. if(!block.set_comment(0, entry2))
  1181. return die_("returned false");
  1182. if(block.get_comment(0).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[0].length)
  1183. return die_("length mismatch");
  1184. if(0 != memcmp(block.get_comment(0).get_field(), vorbiscomment_.data.vorbis_comment.comments[0].entry, vorbiscomment_.data.vorbis_comment.comments[0].length))
  1185. return die_("value mismatch");
  1186. printf("OKn");
  1187. printf("testing VorbisComment::delete_comment()... +n");
  1188. printf("        VorbisComment::get_comment()... ");
  1189. if(!block.delete_comment(0))
  1190. return die_("returned false");
  1191. if(block.get_comment(0).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[0].length)
  1192. return die_("length[0] mismatch");
  1193. if(0 != memcmp(block.get_comment(0).get_field(), vorbiscomment_.data.vorbis_comment.comments[0].entry, vorbiscomment_.data.vorbis_comment.comments[0].length))
  1194. return die_("value[0] mismatch");
  1195. if(block.get_comment(1).get_field_length() != vorbiscomment_.data.vorbis_comment.comments[1].length)
  1196. return die_("length[1] mismatch");
  1197. if(0 != memcmp(block.get_comment(1).get_field(), vorbiscomment_.data.vorbis_comment.comments[1].entry, vorbiscomment_.data.vorbis_comment.comments[1].length))
  1198. return die_("value[0] mismatch");
  1199. printf("OKn");
  1200. printf("testing FLAC::Metadata::clone(const FLAC::Metadata::Prototype *)... ");
  1201. FLAC::Metadata::Prototype *clone_ = FLAC::Metadata::clone(&block);
  1202. if(0 == clone_)
  1203. return die_("returned NULL");
  1204. if(0 == dynamic_cast<FLAC::Metadata::VorbisComment *>(clone_))
  1205. return die_("downcast is NULL");
  1206. if(*dynamic_cast<FLAC::Metadata::VorbisComment *>(clone_) != block)
  1207. return die_("clone is not identical");
  1208. printf("OKn");
  1209. printf("testing VorbisComment::~VorbisComment()... ");
  1210. delete clone_;
  1211. printf("OKn");
  1212. printf("PASSEDnn");
  1213. return true;
  1214. }
  1215. bool test_metadata_object_cuesheet()
  1216. {
  1217. unsigned expected_length;
  1218. printf("testing class FLAC::Metadata::CueSheet::Trackn");
  1219. printf("testing Track::Track()... ");
  1220. FLAC::Metadata::CueSheet::Track track0;
  1221. if(!track0.is_valid())
  1222. return die_("!is_valid()");
  1223. printf("OKn");
  1224. {
  1225. printf("testing Track::get_track()... ");
  1226. const ::FLAC__StreamMetadata_CueSheet_Track *trackp = track0.get_track();
  1227. if(0 == trackp)
  1228. return die_("returned pointer is NULL");
  1229. printf("OKn");
  1230. printf("testing Track::Track(const ::FLAC__StreamMetadata_CueSheet_Track*)... ");
  1231. FLAC::Metadata::CueSheet::Track track2(trackp);
  1232. if(!track2.is_valid())
  1233. return die_("!is_valid()");
  1234. if(!track_is_equal_(track2.get_track(), trackp))
  1235. return die_("copy is not equal");
  1236. printf("OKn");
  1237. printf("testing Track::~Track()... ");
  1238. }
  1239. printf("OKn");
  1240. printf("testing Track::Track(const Track &track)... ");
  1241. {
  1242. FLAC::Metadata::CueSheet::Track track0copy(track0);
  1243. if(!track0copy.is_valid())
  1244. return die_("!is_valid()");
  1245. if(!track_is_equal_(track0copy.get_track(), track0.get_track()))
  1246. return die_("copy is not equal");
  1247. printf("OKn");
  1248. printf("testing Track::~Track()... ");
  1249. }
  1250. printf("OKn");
  1251. printf("testing Track::operator=(const Track &track)... ");
  1252. FLAC::Metadata::CueSheet::Track track1 = track0;
  1253. if(!track0.is_valid())
  1254. return die_("!is_valid()");
  1255. if(!track_is_equal_(track1.get_track(), track0.get_track()))
  1256. return die_("copy is not equal");
  1257. printf("OKn");
  1258. printf("testing Track::get_offset()... ");
  1259. if(track1.get_offset() != 0)
  1260. return die_("value mismatch");
  1261. printf("OKn");
  1262. printf("testing Track::get_number()... ");
  1263. if(track1.get_number() != 0)
  1264. return die_("value mismatch");
  1265. printf("OKn");
  1266. printf("testing Track::get_isrc()... ");
  1267. if(0 != memcmp(track1.get_isrc(), "", 13))
  1268. return die_("value mismatch");
  1269. printf("OKn");
  1270. printf("testing Track::get_type()... ");
  1271. if(track1.get_type() != 0)
  1272. return die_("value mismatch");
  1273. printf("OKn");
  1274. printf("testing Track::get_pre_emphasis()... ");
  1275. if(track1.get_pre_emphasis() != 0)
  1276. return die_("value mismatch");
  1277. printf("OKn");
  1278. printf("testing Track::get_num_indices()... ");
  1279. if(track1.get_num_indices() != 0)
  1280. return die_("value mismatch");
  1281. printf("OKn");
  1282. printf("testing Track::set_offset()... ");
  1283. track1.set_offset(588);
  1284. if(track1.get_offset() != 588)
  1285. return die_("value mismatch");
  1286. printf("OKn");
  1287. printf("testing Track::set_number()... ");
  1288. track1.set_number(1);
  1289. if(track1.get_number() != 1)
  1290. return die_("value mismatch");
  1291. printf("OKn");
  1292. printf("testing Track::set_isrc()... ");
  1293. track1.set_isrc("ABCDE1234567");
  1294. if(0 != memcmp(track1.get_isrc(), "ABCDE1234567", 13))
  1295. return die_("value mismatch");
  1296. printf("OKn");
  1297. printf("testing Track::set_type()... ");
  1298. track1.set_type(1);
  1299. if(track1.get_type() != 1)
  1300. return die_("value mismatch");
  1301. printf("OKn");
  1302. printf("testing Track::set_pre_emphasis()... ");
  1303. track1.set_pre_emphasis(1);
  1304. if(track1.get_pre_emphasis() != 1)
  1305. return die_("value mismatch");
  1306. printf("OKn");
  1307. printf("PASSEDnn");
  1308. printf("testing class FLAC::Metadata::CueSheetn");
  1309. printf("testing CueSheet::CueSheet()... ");
  1310. FLAC::Metadata::CueSheet block;
  1311. if(!block.is_valid())
  1312. return die_("!block.is_valid()");
  1313. expected_length = (
  1314. FLAC__STREAM_METADATA_CUESHEET_MEDIA_CATALOG_NUMBER_LEN +
  1315. FLAC__STREAM_METADATA_CUESHEET_LEAD_IN_LEN +
  1316. FLAC__STREAM_METADATA_CUESHEET_IS_CD_LEN +
  1317. FLAC__STREAM_METADATA_CUESHEET_RESERVED_LEN +
  1318. FLAC__STREAM_METADATA_CUESHEET_NUM_TRACKS_LEN
  1319. ) / 8;
  1320. if(block.get_length() != expected_length) {
  1321. printf("FAILED, bad length, expected %u, got %un", expected_length, block.get_length());
  1322. return false;
  1323. }
  1324. printf("OKn");
  1325. printf("testing CueSheet::CueSheet(const CueSheet &)... +n");
  1326. printf("        CueSheet::operator!=(const CueSheet &)... ");
  1327. {
  1328. FLAC::Metadata::CueSheet blockcopy(block);
  1329. if(!blockcopy.is_valid())
  1330. return die_("!block.is_valid()");
  1331. if(blockcopy != block)
  1332. return die_("copy is not identical to original");
  1333. printf("OKn");
  1334. printf("testing CueSheet::~CueSheet()... ");
  1335. }
  1336. printf("OKn");
  1337. printf("testing CueSheet::CueSheet(const ::FLAC__StreamMetadata &)... +n");
  1338. printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata &)... ");
  1339. {
  1340. FLAC::Metadata::CueSheet blockcopy(cuesheet_);
  1341. if(!blockcopy.is_valid())
  1342. return die_("!block.is_valid()");
  1343. if(blockcopy != cuesheet_)
  1344. return die_("copy is not identical to original");
  1345. printf("OKn");
  1346. }
  1347. printf("testing CueSheet::CueSheet(const ::FLAC__StreamMetadata *)... +n");
  1348. printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
  1349. {
  1350. FLAC::Metadata::CueSheet blockcopy(&cuesheet_);
  1351. if(!blockcopy.is_valid())
  1352. return die_("!block.is_valid()");
  1353. if(blockcopy != cuesheet_)
  1354. return die_("copy is not identical to original");
  1355. printf("OKn");
  1356. }
  1357. printf("testing CueSheet::CueSheet(const ::FLAC__StreamMetadata *, copy=true)... +n");
  1358. printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
  1359. {
  1360. FLAC::Metadata::CueSheet blockcopy(&cuesheet_, /*copy=*/true);
  1361. if(!blockcopy.is_valid())
  1362. return die_("!block.is_valid()");
  1363. if(blockcopy != cuesheet_)
  1364. return die_("copy is not identical to original");
  1365. printf("OKn");
  1366. }
  1367. printf("testing CueSheet::CueSheet(const ::FLAC__StreamMetadata *, copy=false)... +n");
  1368. printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
  1369. {
  1370. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&cuesheet_);
  1371. FLAC::Metadata::CueSheet blockcopy(copy, /*copy=*/false);
  1372. if(!blockcopy.is_valid())
  1373. return die_("!block.is_valid()");
  1374. if(blockcopy != cuesheet_)
  1375. return die_("copy is not identical to original");
  1376. printf("OKn");
  1377. }
  1378. printf("testing CueSheet::assign(const ::FLAC__StreamMetadata *, copy=true)... +n");
  1379. printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
  1380. {
  1381. FLAC::Metadata::CueSheet blockcopy;
  1382. blockcopy.assign(&cuesheet_, /*copy=*/true);
  1383. if(!blockcopy.is_valid())
  1384. return die_("!block.is_valid()");
  1385. if(blockcopy != cuesheet_)
  1386. return die_("copy is not identical to original");
  1387. printf("OKn");
  1388. }
  1389. printf("testing CueSheet::assign(const ::FLAC__StreamMetadata *, copy=false)... +n");
  1390. printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
  1391. {
  1392. ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&cuesheet_);
  1393. FLAC::Metadata::CueSheet blockcopy;
  1394. blockcopy.assign(copy, /*copy=*/false);
  1395. if(!blockcopy.is_valid())
  1396. return die_("!block.is_valid()");
  1397. if(blockcopy != cuesheet_)
  1398. return die_("copy is not identical to original");
  1399. printf("OKn");
  1400. }
  1401. printf("testing CueSheet::operator=(const CueSheet &)... +n");
  1402. printf("        CueSheet::operator==(const CueSheet &)... ");
  1403. {
  1404. FLAC::Metadata::CueSheet blockcopy = block;
  1405. if(!blockcopy.is_valid())
  1406. return die_("!block.is_valid()");
  1407. if(!(blockcopy == block))
  1408. return die_("copy is not identical to original");
  1409. printf("OKn");
  1410. }
  1411. printf("testing CueSheet::operator=(const ::FLAC__StreamMetadata &)... +n");
  1412. printf("        CueSheet::operator==(const ::FLAC__StreamMetadata &)... ");
  1413. {
  1414. FLAC::Metadata::CueSheet blockcopy = cuesheet_;
  1415. if(!blockcopy.is_valid())
  1416. return die_("!block.is_valid()");
  1417. if(!(blockcopy == cuesheet_))
  1418. return die_("copy is not identical to original");
  1419. printf("OKn");
  1420. }
  1421. printf("testing CueSheet::operator=(const ::FLAC__StreamMetadata *)... +n");
  1422. printf("        CueSheet::operator==(const ::FLAC__StreamMetadata *)... ");
  1423. {
  1424. FLAC::Metadata::CueSheet blockcopy = &cuesheet_;
  1425. if(!blockcopy.is_valid())
  1426. return die_("!block.is_valid()");
  1427. if(!(blockcopy == cuesheet_))
  1428. return die_("copy is not identical to original");
  1429. printf("OKn");
  1430. }
  1431. printf("testing CueSheet::get_media_catalog_number()... ");
  1432. if(0 != strcmp(block.get_media_catalog_number(), ""))
  1433. return die_("value mismatch");
  1434. printf("OKn");
  1435. printf("testing CueSheet::get_lead_in()... ");
  1436. if(block.get_lead_in() != 0)
  1437. return die_("value mismatch, expected 0");
  1438. printf("OKn");
  1439. printf("testing CueSheet::get_is_cd()... ");
  1440. if(block.get_is_cd())
  1441. return die_("value mismatch, expected false");
  1442. printf("OKn");
  1443. printf("testing CueSheet::get_num_tracks()... ");
  1444. if(block.get_num_tracks() != 0)
  1445. return die_("value mismatch, expected 0");
  1446. printf("OKn");
  1447. printf("testing CueSheet::set_media_catalog_number()... ");
  1448. {
  1449. char mcn[129];
  1450. memset(mcn, 0, sizeof(mcn));
  1451. strcpy(mcn, "1234567890123");
  1452. block.set_media_catalog_number(mcn);
  1453. if(0 != memcmp(block.get_media_catalog_number(), mcn, sizeof(mcn)))
  1454. return die_("value mismatch");
  1455. }
  1456. printf("OKn");
  1457. printf("testing CueSheet::set_lead_in()... ");
  1458. block.set_lead_in(588);
  1459. if(block.get_lead_in() != 588)
  1460. return die_("value mismatch");
  1461. printf("OKn");
  1462. printf("testing CueSheet::set_is_cd()... ");
  1463. block.set_is_cd(true);
  1464. if(!block.get_is_cd())
  1465. return die_("value mismatch");
  1466. printf("OKn");
  1467. printf("testing CueSheet::insert_track()... +n");
  1468. printf("        CueSheet::get_track()... ");
  1469. if(!block.insert_track(0, track0))
  1470. return die_("returned false");
  1471. if(!track_is_equal_(block.get_track(0).get_track(), track0.get_track()))
  1472. return die_("value mismatch");
  1473. printf("OKn");
  1474. printf("testing CueSheet::insert_track()... +n");
  1475. printf("        CueSheet::get_track()... ");
  1476. if(!block.insert_track(1, track1))
  1477. return die_("returned false");
  1478. if(!track_is_equal_(block.get_track(1).get_track(), track1.get_track()))
  1479. return die_("value mismatch");
  1480. printf("OKn");
  1481. ::FLAC__StreamMetadata_CueSheet_Index index0;
  1482. index0.offset = 588*4;
  1483. index0.number = 1;
  1484. printf("testing CueSheet::insert_index(0)... +n");
  1485. printf("        CueSheet::get_track()... +n");
  1486. printf("        CueSheet::Track::get_index()... ");
  1487. if(!block.insert_index(0, 0, index0))
  1488. return die_("returned false");
  1489. if(!index_is_equal_(block.get_track(0).get_index(0), index0))
  1490. return die_("value mismatch");
  1491. printf("OKn");
  1492. index0.offset = 588*5;
  1493. printf("testing CueSheet::Track::set_index()... ");
  1494. {
  1495. FLAC::Metadata::CueSheet::Track track_ = block.get_track(0);
  1496. track_.set_index(0, index0);
  1497. if(!index_is_equal_(track_.get_index(0), index0))
  1498. return die_("value mismatch");
  1499. }
  1500. printf("OKn");
  1501. index0.offset = 588*6;
  1502. printf("testing CueSheet::set_index()... ");
  1503. block.set_index(0, 0, index0);
  1504. if(!index_is_equal_(block.get_track(0).get_index(0), index0))
  1505. return die_("value mismatch");
  1506. printf("OKn");
  1507. printf("testing CueSheet::delete_index()... ");
  1508. if(!block.delete_index(0, 0))
  1509. return die_("returned false");
  1510. if(block.get_track(0).get_num_indices() != 0)
  1511. return die_("num_indices mismatch");
  1512. printf("OKn");
  1513. printf("testing CueSheet::set_track()... +n");
  1514. printf("        CueSheet::get_track()... ");
  1515. if(!block.set_track(0, track1))
  1516. return die_("returned false");
  1517. if(!track_is_equal_(block.get_track(0).get_track(), track1.get_track()))
  1518. return die_("value mismatch");
  1519. printf("OKn");
  1520. printf("testing CueSheet::delete_track()... ");
  1521. if(!block.delete_track(0))
  1522. return die_("returned false");
  1523. if(block.get_num_tracks() != 1)
  1524. return die_("num_tracks mismatch");
  1525. printf("OKn");
  1526. printf("testing FLAC::Metadata::clone(const FLAC::Metadata::Prototype *)... ");
  1527. FLAC::Metadata::Prototype *clone_ = FLAC::Metadata::clone(&block);
  1528. if(0 == clone_)
  1529. return die_("returned NULL");
  1530. if(0 == dynamic_cast<FLAC::Metadata::CueSheet *>(clone_))
  1531. return die_("downcast is NULL");
  1532. if(*dynamic_cast<FLAC::Metadata::CueSheet *>(clone_) != block)
  1533. return die_("clone is not identical");
  1534. printf("OKn");
  1535. printf("testing CueSheet::~CueSheet()... ");
  1536. delete clone_;
  1537. printf("OKn");
  1538. printf("PASSEDnn");
  1539. return true;
  1540. }
  1541. bool test_metadata_object()
  1542. {
  1543. printf("n+++ libFLAC++ unit test: metadata objectsnn");
  1544. init_metadata_blocks_();
  1545. if(!test_metadata_object_streaminfo())
  1546. return false;
  1547. if(!test_metadata_object_padding())
  1548. return false;
  1549. if(!test_metadata_object_application())
  1550. return false;
  1551. if(!test_metadata_object_seektable())
  1552. return false;
  1553. if(!test_metadata_object_vorbiscomment())
  1554. return false;
  1555. if(!test_metadata_object_cuesheet())
  1556. return false;
  1557. free_metadata_blocks_();
  1558. return true;
  1559. }