 Chromium Code Reviews
 Chromium Code Reviews Issue 2723083004:
  Remove a scoped_refptr<>::swap overload  (Closed)
    
  
    Issue 2723083004:
  Remove a scoped_refptr<>::swap overload  (Closed) 
  | Index: media/filters/ffmpeg_audio_decoder.cc | 
| diff --git a/media/filters/ffmpeg_audio_decoder.cc b/media/filters/ffmpeg_audio_decoder.cc | 
| index e3560ff1b8bcf9d359f2a7c0ab06147b8e6b4e3f..06233eaa7d141c033ac0c80a7574defee61d04ba 100644 | 
| --- a/media/filters/ffmpeg_audio_decoder.cc | 
| +++ b/media/filters/ffmpeg_audio_decoder.cc | 
| @@ -45,8 +45,8 @@ static inline int DetermineChannels(AVFrame* frame) { | 
| // Called by FFmpeg's allocation routine to free a buffer. |opaque| is the | 
| // AudioBuffer allocated, so unref it. | 
| static void ReleaseAudioBufferImpl(void* opaque, uint8_t* data) { | 
| - scoped_refptr<AudioBuffer> buffer; | 
| - buffer.swap(reinterpret_cast<AudioBuffer**>(&opaque)); | 
| + if (opaque) | 
| + static_cast<AudioBuffer*>(opaque)->Release(); | 
| } | 
| // Called by FFmpeg's allocation routine to allocate a buffer. Uses | 
| @@ -124,8 +124,8 @@ static int GetAudioBuffer(struct AVCodecContext* s, AVFrame* frame, int flags) { | 
| // Now create an AVBufferRef for the data just allocated. It will own the | 
| // reference to the AudioBuffer object. | 
| - void* opaque = NULL; | 
| - buffer.swap(reinterpret_cast<AudioBuffer**>(&opaque)); | 
| + AudioBuffer* opaque = buffer.get(); | 
| + opaque->AddRef(); | 
| 
xhwang
2017/03/03 18:36:08
This is hard to read (not saying it's worse than b
 
dcheng
2017/03/03 18:45:19
Eh... this seems Good Enough (tm) for the use case
 | 
| frame->buf[0] = av_buffer_create( | 
| frame->data[0], buffer_size_in_bytes, ReleaseAudioBufferImpl, opaque, 0); | 
| return 0; |