static void load_id666(service_ptr_t<file> & p_file, LPID666TAG lpTag, abort_callback & p_abort)//must be seeked to correct spot before calling { t_uint8 szBuf[4]; p_file->read_object( &szBuf, 4, p_abort ); if( ! memcmp( szBuf, xid6_signature, 4 ) ) { t_uint32 tag_size; p_file->read_lendian_t( tag_size, p_abort ); t_filesize offset = p_file->get_position( p_abort ); service_ptr_t< reader_limited > m_file = new service_impl_t< reader_limited >; m_file->init( p_file, offset, offset + tag_size, p_abort ); service_ptr_t<file> p_file = m_file.get_ptr(); try { parse_id666( p_file, lpTag, false, p_abort ); } catch ( const exception_io_data & ) { p_file->seek( 0, p_abort ); memset( lpTag, 0, sizeof( *lpTag ) ); parse_id666( p_file, lpTag, true, p_abort ); } } else throw exception_tag_not_found(); }
void file::g_transfer_object(service_ptr_t<file> p_src,service_ptr_t<file> p_dst,t_filesize p_bytes,abort_callback & p_abort) { if (p_bytes > 1024) /* don't bother on small objects */ { t_filesize oldsize = p_dst->get_size(p_abort); if (oldsize != filesize_invalid) { t_filesize newpos = p_dst->get_position(p_abort) + p_bytes; if (newpos > oldsize) p_dst->resize(newpos ,p_abort); } } g_transfer_object(pfc::implicit_cast<stream_reader*>(p_src.get_ptr()),pfc::implicit_cast<stream_writer*>(p_dst.get_ptr()),p_bytes,p_abort); }
foobar_File_Reader::foobar_File_Reader( const service_ptr_t<file> & p_file, abort_callback & p_abort ) : m_file( p_file ), m_abort( p_abort ) { set_size( p_file->get_size_ex( p_abort ) ); set_tell( p_file->get_position( p_abort ) ); }
write_xid6( service_ptr_t<file> & p_file, const file_info & p_info, abort_callback & p_abort ) : m_file( p_file ), m_abort( p_abort ) { pfc::stringcvt::string_ansi_from_utf8 converter; t_filesize offset_tag_start; const char * value; t_uint32 int32 = 0; p_file->seek_ex( 0, file::seek_from_eof, p_abort ); p_file->write_object( xid6_signature, 4, p_abort ); p_file->write_object_t( int32, p_abort ); offset_tag_start = p_file->get_position( p_abort ); value = p_info.meta_get( "title", 0 ); if ( value ) { converter.convert( value ); if ( strlen( converter ) > 32 ) write_string( XID_SONG, converter ); } value = p_info.meta_get( "album", 0 ); if ( value ) { converter.convert( value ); if ( strlen( converter ) > 32 ) write_string( XID_GAME, converter ); } value = p_info.meta_get( "artist", 0 ); if ( value ) { converter.convert( value ); if ( strlen( converter ) > 32 ) write_string( XID_ARTIST, converter ); } value = p_info.meta_get( "dumper", 0 ); if ( value ) { converter.convert( value ); if ( strlen( converter ) > 16 ) write_string( XID_DUMPER, converter ); } value = p_info.meta_get( "comment", 0 ); if ( value ) { converter.convert( value ); if ( strlen( converter ) > 32 ) write_string( XID_CMNTS, converter ); } value = p_info.meta_get( "OST", 0 ); if ( value ) { converter.convert( value ); write_string( XID_OST, converter ); } value = p_info.meta_get( "discnumber", 0 ); if ( value ) { char * end; unsigned disc = strtoul( value, &end, 10 ); if ( !*end && disc > 0 && disc <= 9 ) write_data( XID_DISC, disc ); } value = p_info.meta_get( "tracknumber", 0 ); if ( value ) { char * end; unsigned track = strtoul( value, &end, 10 ); if ( track > 0 && track < 100 ) write_data( XID_TRACK, track * 0x100 + *end ); } value = p_info.meta_get( "copyright", 0 ); if ( value ) { char * end; unsigned copyright_year = strtoul( value, &end, 10 ); if ( copyright_year > 0 && copyright_year < 65536 ) write_data( XID_COPY, copyright_year ); while ( *end && *end == ' ' ) end++; if ( *end ) { converter.convert( end ); write_string( XID_PUB, converter ); } } value = p_info.info_get( field_length ); if ( value ) { char * end; unsigned length = strtoul( value, &end, 10 ); if ( !*end && length > 0 && ( length % 1000 || length > 999000 ) ) write_int( XID_INTRO, length * 64 ); } value = p_info.info_get( field_fade ); if ( value ) { char * end; unsigned fade = strtoul( value, &end, 10 ); if ( !*end && fade > 99999 ) write_int( XID_FADE, fade * 64 ); } t_filesize offset = p_file->get_position( p_abort ); offset -= offset_tag_start; if ( offset > ( 1 << 30 ) ) throw exception_io_data(); if ( offset ) { int32 = t_uint32( offset ); p_file->seek( offset_tag_start - 4, p_abort ); p_file->write_lendian_t( int32, p_abort ); } else { p_file->seek( offset_tag_start - 8, p_abort ); p_file->set_eof( p_abort ); } }