--- deliantra/Deliantra-Client/DC/Protocol.pm 2007/07/13 15:44:48 1.118 +++ deliantra/Deliantra-Client/DC/Protocol.pm 2007/07/14 12:05:53 1.119 @@ -69,25 +69,30 @@ # check if already cached CFPlus::DB::get "res-metadata" => $chksum, sub { - my ($meta) = @_; + my ($meta_json) = @_; - if (defined $meta) { - $self->{music_meta}{$chksum} = $self->{json_coder}->decode ($meta); + if (defined $meta_json) { + my $meta = $self->{json_coder}->decode ($meta_json); + $meta->{path} = CFPlus::DB::path_of_res $chksum; + $self->{music_meta}{$chksum} = $meta; } else { ::message ({ markup => "starting to download song #$face/$pri, check your output-rate setting if your connection gets laggy." }); $self->ask_face ($face, -100 - $pri, undef, sub { my $len = length $_[1]; - my ($meta, $data) = unpack "(w/a*)*", $_[1]; + my ($meta_json, $data) = unpack "(w/a*)*", $_[1]; - CFPlus::DB::write_file $chksum, $data, sub { }; - CFPlus::DB::put "res-metadata" => $chksum => $meta, sub { }; + my $meta = $self->{json_coder}->decode ($meta_json); + $meta->{path} = CFPlus::DB::path_of_res $chksum; + $self->{music_meta}{$chksum} = $meta; - $self->{music_meta}{$chksum} = $self->{json_coder}->decode ($meta); - ::message ({ markup => "downloaded song #$face, size $len octets" }); + CFPlus::DB::write_file $meta->{path}, $data, sub { }; + CFPlus::DB::put "res-metadata" => $chksum => $meta_json, sub { }; - &::audio_music_set ($self->{songs}); + ::message ({ markup => "downloaded song #$face, size $len octets" }); }); } + + &::audio_music_set ($self->{songs}); } } }