diff --git a/multimedia/py-ffmpeg/Makefile b/multimedia/py-ffmpeg/Makefile index a20486e74d85..2d4ced0af46e 100644 --- a/multimedia/py-ffmpeg/Makefile +++ b/multimedia/py-ffmpeg/Makefile @@ -3,7 +3,7 @@ PORTNAME= ffmpeg PORTVERSION= 1.2.4 -PORTREVISION= 3 +PORTREVISION= 4 CATEGORIES= multimedia python MASTER_SITES= GH LOCAL/dbn/${PORTNAME} PKGNAMEPREFIX= ${PYTHON_PKGNAMEPREFIX} diff --git a/multimedia/py-ffmpeg/files/patch-ffmpeg___ffmpeg.pxi b/multimedia/py-ffmpeg/files/patch-ffmpeg___ffmpeg.pxi index 197a63c7e2ef..5fd1fb4dc712 100644 --- a/multimedia/py-ffmpeg/files/patch-ffmpeg___ffmpeg.pxi +++ b/multimedia/py-ffmpeg/files/patch-ffmpeg___ffmpeg.pxi @@ -1,6 +1,14 @@ --- ffmpeg/_ffmpeg.pxi.orig 2013-10-28 16:04:02 UTC +++ ffmpeg/_ffmpeg.pxi -@@ -53,8 +53,6 @@ cdef extern from "libavcodec/avcodec.h" +@@ -35,6 +35,7 @@ cdef extern from "libavcodec/avcodec.h" + unsigned char **data + int *linesize + int64_t pts ++ int64_t pkt_pts; + int repeat_pict + int nb_samples + int format +@@ -53,8 +54,6 @@ cdef extern from "libavcodec/avcodec.h" int channels AVCodec *codec AVMediaType codec_type @@ -9,7 +17,7 @@ AVRational time_base AVSampleFormat sample_fmt struct AVPicture: -@@ -83,7 +81,7 @@ cdef extern from "libavcodec/avcodec.h" +@@ -83,7 +82,7 @@ cdef extern from "libavcodec/avcodec.h" ctypedef int (*lockmgr_t)(void **mutex, AVLockOp op) int av_lockmgr_register(lockmgr_t cb) @@ -18,7 +26,7 @@ int avcodec_decode_video2(AVCodecContext *avctx, AVFrame *picture, int *got_picture_ptr, AVPacket *avpkt) int avcodec_decode_audio4(AVCodecContext *avctx, AVFrame *frame, int -@@ -100,7 +98,7 @@ cdef extern from "libavcodec/avcodec.h" +@@ -100,7 +99,7 @@ cdef extern from "libavcodec/avcodec.h" int avcodec_default_get_buffer(AVCodecContext *s, AVFrame *pic) void avcodec_default_release_buffer(AVCodecContext *s, AVFrame *pic) diff --git a/multimedia/py-ffmpeg/files/patch-ffmpeg___ffmpeg.pyx b/multimedia/py-ffmpeg/files/patch-ffmpeg___ffmpeg.pyx index 199d605de161..a1071885a891 100644 --- a/multimedia/py-ffmpeg/files/patch-ffmpeg___ffmpeg.pyx +++ b/multimedia/py-ffmpeg/files/patch-ffmpeg___ffmpeg.pyx @@ -1,6 +1,15 @@ --- ffmpeg/_ffmpeg.pyx.orig 2013-10-28 16:04:02 UTC +++ ffmpeg/_ffmpeg.pyx -@@ -518,11 +518,11 @@ cdef int audio_decode_frame(VideoState * +@@ -81,8 +81,6 @@ DEF FF_REFRESH_EVENT = 2 + DEF FF_QUIT_EVENT = 3 + DEF FF_SCHEDULE_EVENT = 4 + +-cdef uint64_t global_video_pkt_pts = AV_NOPTS_VALUE +- + ctypedef void (*event_callback_t)(void *) + + cdef struct Event: +@@ -518,11 +516,11 @@ cdef int audio_decode_frame(VideoState * got_frame = 0 if frame == NULL: @@ -14,7 +23,7 @@ len1 = avcodec_decode_audio4(vs.audio_st.codec, frame, &got_frame, pkt) -@@ -784,7 +784,7 @@ cdef void alloc_picture(void *userdata) +@@ -784,7 +782,7 @@ cdef void alloc_picture(void *userdata) vp.ff_data_size = avpicture_get_size(PF_RGB24, vp.width, vp.height) vp.ff_data = av_malloc(vp.ff_data_size * sizeof(unsigned char)) @@ -23,7 +32,7 @@ avpicture_fill(vp.bmp, vp.ff_data, PF_RGB24, vp.width, vp.height) -@@ -886,19 +886,6 @@ cdef double synchronize_video(VideoState +@@ -886,19 +884,6 @@ cdef double synchronize_video(VideoState return pts @@ -43,7 +52,7 @@ cdef int video_thread(void *arg) nogil: cdef VideoState *vs = arg cdef AVPacket pkt1, *packet = &pkt1 -@@ -906,7 +893,7 @@ cdef int video_thread(void *arg) nogil: +@@ -906,7 +891,7 @@ cdef int video_thread(void *arg) nogil: cdef AVFrame *pFrame cdef double pts, ptst = 0 @@ -52,7 +61,27 @@ while True: if packet_queue_get(&vs.videoq, packet, 1) < 0: -@@ -1038,8 +1025,6 @@ cdef int stream_component_open(VideoStat +@@ -919,16 +904,13 @@ cdef int video_thread(void *arg) nogil: + + pts = 0 + +- # Save global pts to be stored in pFrame +- global_video_pkt_pts = packet.pts + # Decode video frame + with gil: + len1 = avcodec_decode_video2( + vs.video_st.codec, pFrame, &frameFinished, packet) +- if packet.dts == AV_NOPTS_VALUE and pFrame.opaque: +- memcpy(&ptst, pFrame.opaque, sizeof(uint64_t)) +- if ptst != AV_NOPTS_VALUE: +- pts = ptst ++ if packet.dts == AV_NOPTS_VALUE: ++ if pFrame.pkt_pts != AV_NOPTS_VALUE: ++ pts = pFrame.pkt_pts + elif packet.dts != AV_NOPTS_VALUE: + pts = packet.dts + else: +@@ -1038,8 +1020,6 @@ cdef int stream_component_open(VideoStat packet_queue_init(&vs.videoq) vs.video_tid = SDL_CreateThread(video_thread, vs)