From: Good Guy Date: Sun, 1 Mar 2020 02:42:26 +0000 (-0700) Subject: version update, chg shortcut for del last trk, ogg fixes/tweaks X-Git-Tag: 2020-02 X-Git-Url: https://cinelerra-gg.org/git/?a=commitdiff_plain;h=e4db3b86fa63309c123ee1222858cb405b3a448c;p=goodguy%2Fcinelerra.git version update, chg shortcut for del last trk, ogg fixes/tweaks --- diff --git a/cinelerra-5.1/blds/PKGBUILD b/cinelerra-5.1/blds/PKGBUILD index ea6a2992..7d48a653 100644 --- a/cinelerra-5.1/blds/PKGBUILD +++ b/cinelerra-5.1/blds/PKGBUILD @@ -1,7 +1,7 @@ # Maintainer: goodguy pkgname=cin pkgver=5.1 -pkgrel=20200131 +pkgrel=20200229 pkgdesc="Cinelerra git://git.cinelerra-gg.org/goodguy/cinelerra.git ($pkgrel)" arch=('x86_64') url="https://www.cinelerra-gg.org" diff --git a/cinelerra-5.1/blds/cinelerra.spec b/cinelerra-5.1/blds/cinelerra.spec index 21d9f835..2f0ee8f3 100644 --- a/cinelerra-5.1/blds/cinelerra.spec +++ b/cinelerra-5.1/blds/cinelerra.spec @@ -1,4 +1,4 @@ -%define ver 20200131 +%define ver 20200229 %define cin cinelerra Summary: Multimedia Editing and construction @@ -52,7 +52,7 @@ BuildRequires: texinfo BuildRequires: gtk2-devel BuildRequires: libva-devel BuildRequires: libvdpau-devel -BuildRequires: pulseaudio-libs-devel +%{?rhat:BuildRequires: pulseaudio-libs-devel} %{?rhat:BuildRequires: alsa-lib-devel} %{?rhat:BuildRequires: bzip2-devel} %{?rhat:BuildRequires: xorg-x11-fonts-cyrillic} @@ -61,6 +61,7 @@ BuildRequires: pulseaudio-libs-devel %{?rhat:BuildRequires: xorg-x11-fonts-ISO8859-1-75dpi} %{?rhat:BuildRequires: xorg-x11-fonts-misc} %{?rhat:BuildRequires: xorg-x11-fonts-Type1} +%{?suse:BuildRequires: libpulse-devel} %{?suse:BuildRequires: alsa-devel} %{?suse:BuildRequires: libbz2-devel} %{?suse:BuildRequires: bitstream-vera-fonts} diff --git a/cinelerra-5.1/blds/debian/changelog b/cinelerra-5.1/blds/debian/changelog index 8b9d436c..731b74c2 100644 --- a/cinelerra-5.1/blds/debian/changelog +++ b/cinelerra-5.1/blds/debian/changelog @@ -1,4 +1,4 @@ -cin (1:5.1.20200131) unstable; urgency=low +cin (1:5.1.20200229) unstable; urgency=low [ guy goode ] diff --git a/cinelerra-5.1/blds/debian/control b/cinelerra-5.1/blds/debian/control index b8d50577..dca3842a 100644 --- a/cinelerra-5.1/blds/debian/control +++ b/cinelerra-5.1/blds/debian/control @@ -1,7 +1,7 @@ Source: cin Section: video Priority: optional -Standards-Version: 5.1.20200131 +Standards-Version: 5.1.20200229 Maintainer: mailing list Homepage: https://www.cinelerra-gg.org/ Build-Depends: diff --git a/cinelerra-5.1/cinelerra/Makefile b/cinelerra-5.1/cinelerra/Makefile index d0a8f1ad..f4e536b5 100644 --- a/cinelerra-5.1/cinelerra/Makefile +++ b/cinelerra-5.1/cinelerra/Makefile @@ -552,8 +552,7 @@ clean: rm -f shuttle_keys.h tags: - ctags -R -h default --langmap=c:+.inc . ../guicast/ ../libzmpeg3 ../plugins ../thirdparty/ffmpeg-* \ - ../thirdparty/libtheora* ../thirdparty/libvorbis* ../thirdparty/libogg* + ctags -R -h default --langmap=c:+.inc . ../guicast/ ../libzmpeg3 ../plugins ../thirdparty/ffmpeg-* $(OBJDIR)/fileexr.o: BFLAGS:= -Wno-deprecated $(OBJDIR)/sha1.o: BFLAGS:= -O3 diff --git a/cinelerra-5.1/cinelerra/fileogg.C b/cinelerra-5.1/cinelerra/fileogg.C index 7302bcd1..e65eccbf 100644 --- a/cinelerra-5.1/cinelerra/fileogg.C +++ b/cinelerra-5.1/cinelerra/fileogg.C @@ -1027,6 +1027,7 @@ int FileOGG::ogg_get_page_of_sample(ogg_page *og, int64_t sample) int FileOGG::ogg_seek_to_sample(int64_t ogg_sample) { ogg_page og; + ogg_packet op; if( !ogg_get_page_of_sample(&og, ogg_sample) ) { eprintf(_("Seeking to sample's page failed\n")); return 0; @@ -1038,13 +1039,13 @@ int FileOGG::ogg_seek_to_sample(int64_t ogg_sample) while( (ret=audiosync->ogg_get_prev_page(to.serialno, &og)) && (ogg_page_packets(&og) == 0 && ogg_page_continued(&og)) ); } - audio_eos = 0; - ogg_stream_reset(&vo); - ogg_stream_pagein(&vo, &og); - vorbis_synthesis_restart(&vd); - ogg_packet op; - while( (ret=ogg_get_audio_packet(&op)) != 0 && - op.granulepos < 0 ); + if( ret ) { + audio_eos = 0; + ogg_stream_reset(&vo); + ogg_stream_pagein(&vo, &og); + vorbis_synthesis_restart(&vd); + ret = ogg_get_audio_packet(&op); + } if( ret && !vorbis_synthesis(&vb, &op) ) { vorbis_synthesis_blockin(&vd, &vb); if( vorbis_synthesis_pcmout(&vd, 0) ) @@ -1055,7 +1056,7 @@ int FileOGG::ogg_seek_to_sample(int64_t ogg_sample) return 0; } - while( ogg_sample >= next_pos ) { + while( ogg_sample > next_pos ) { if( !(ret=ogg_get_audio_packet(&op)) ) break; if( vorbis_synthesis(&vb, &op) ) continue; vorbis_synthesis_blockin(&vd, &vb); @@ -1270,13 +1271,9 @@ int FileOGG::read_frame(VFrame *frame) } expect_keyframe = 1; } - int frames_remaining = asset->video_length - (video_pos - start_frame); - if( decode_frames > frames_remaining ) decode_frames = frames_remaining; int ret = 0; ogg_packet op; - while( decode_frames > 0 && !video_eos ) { - if( video_pos-start_frame >= asset->video_length ) - return 0; + while( decode_frames > 0 ) { if( !ogg_get_video_packet(&op) ) break; if( expect_keyframe ) { expect_keyframe = 0; @@ -1343,7 +1340,6 @@ int FileOGG::ogg_decode_more_samples() } } ogg_sample_position = -11; - if( audio_eos ) return 0; eprintf(_("Cannot find next page while trying to decode more samples\n")); return 0; } @@ -1446,22 +1442,28 @@ int FileOGG::read_samples(double *buffer, int64_t len) int64_t sample_demand = samples_to_read - samples_read; int64_t sample_count = MIN(samples_avail, sample_demand); if( sample_count > 0 ) { - for( int i=0; ichannels; ++i ) { - float *input = vorbis_buffer[i]; - float *output = pcm_history[i] + hole_start; - int sz = sample_count*sizeof(*output); - if( samples_waiting ) + int sz = sample_count*sizeof(float); + if( samples_waiting ) { + for( int i=0; ichannels; ++i ) { + float *input = vorbis_buffer[i]; + float *output = pcm_history[i] + hole_start; memcpy(output, input, sz); - else + } + vorbis_synthesis_read(&vd, sample_count); + } + else { + for( int i=0; ichannels; ++i ) { + float *output = pcm_history[i] + hole_start; memset(output, 0, sz); + } } - vorbis_synthesis_read(&vd, sample_count); - samples_read += sample_count; ogg_sample_position += sample_count; hole_start += sample_count; + samples_read += sample_count; + if( samples_read >= hole_len ) break; } - - if( !ogg_decode_more_samples() ) break; + if( samples_read < hole_len && !ogg_decode_more_samples() ) + break; } } diff --git a/cinelerra-5.1/cinelerra/mainmenu.C b/cinelerra-5.1/cinelerra/mainmenu.C index 26b877ed..39e7ef0c 100644 --- a/cinelerra-5.1/cinelerra/mainmenu.C +++ b/cinelerra-5.1/cinelerra/mainmenu.C @@ -1247,8 +1247,10 @@ int DeleteFirstTrack::handle_event() } DeleteLastTrack::DeleteLastTrack(MWindow *mwindow) - : BC_MenuItem(_("Delete last track"), "d", 'd') + : BC_MenuItem(_("Delete last track"), "Ctrl-Shift-D", 'D') { + set_ctrl(1); + set_shift(1); this->mwindow = mwindow; } diff --git a/cinelerra-5.1/msg/txt b/cinelerra-5.1/msg/txt index c5844835..fcac5dd5 100644 --- a/cinelerra-5.1/msg/txt +++ b/cinelerra-5.1/msg/txt @@ -7,6 +7,13 @@ Cinfinity icons selected in Preferences Sam (CC BY 3.0, Cakewalk and Neophyte themes by Olaf Wolff (CC BY 4.0, https://creativecommons.org/licenses/by/4.0/) . +February 2020 New Features of note: + New ColorSpace plugin to convert color space/range. + Updated 17 thirdparty libraries to keep up to date. + Rewrote and replaced OGG/Theora/Vorbis file codec. + Shortcut for "Delete last track" has changed. + PulseAudio option is now built in as audio choice. +. January 2020 New Features of note: Updated reference Manual using LaTeX now complete. File by Reference capability now available. diff --git a/cinelerra-5.1/po/es.po b/cinelerra-5.1/po/es.po index 598540f9..3e3f27e8 100644 --- a/cinelerra-5.1/po/es.po +++ b/cinelerra-5.1/po/es.po @@ -11307,8 +11307,7 @@ msgstr "Compensación vertical" #: plugins/downsample/downsample.C:378 plugins/reframert/reframert.C:241 msgid "Downsample" msgstr "" -"Pixelar\n" -"Bajar Resolución" +"Pixelizar" #: plugins/echo/echo.C:147 msgid "Level: "