- num = time_total / chunk_time + 3;
- PARA_DEBUG_LOG("chunk time: %g allocating %d chunk pointers\n",
- chunk_time, num);
- afhi->chunk_table = para_malloc((num + 1) * sizeof(size_t));
- afhi->chunk_table[0] = 0;
- for (i = 1; i <= num; i++) {
- ogg_int64_t diff, pos;
- ret = ov_time_seek(of, i * chunk_time);
- if (ret)
- break;
- pos = ov_raw_tell(of);
- diff = pos - old_pos;
- max = PARA_MAX(max, diff);
- min = (i == 1)? diff : PARA_MIN(min, diff);
- afhi->chunk_table[i] = pos;
- old_pos = pos;
- }
- num_chunks = i - 1;
- PARA_DEBUG_LOG("%lu chunks (%fs), max chunk: %lld, min chunk: %lld\n",
- num_chunks, chunk_time, (long long)max, (long long)min);
- return num_chunks;
-}
-
-static void ogg_get_vorbis_comments(OggVorbis_File *vf, struct afh_info *afhi)
-{
- vorbis_comment *vc = ov_comment(vf,-1);
-
- if (!vc)
- return;
- afhi->tags.artist = para_strdup(vorbis_comment_query(vc, "artist", 0));
- afhi->tags.title = para_strdup(vorbis_comment_query(vc, "title", 0));
- afhi->tags.album = para_strdup(vorbis_comment_query(vc, "album", 0));
- afhi->tags.year = para_strdup(vorbis_comment_query(vc, "year", 0));
- afhi->tags.comment = para_strdup(vorbis_comment_query(vc, "comment", 0));
+ result->tv_sec = x / 1000 / 1000;
+ result->tv_usec = x % (1000 * 1000);
+ PARA_INFO_LOG("%d chunks, chunk time: %lums\n", num_chunks,
+ tv2ms(result));