X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=test%2Fdcp_playback_test.cc;h=62c72cc84e85fd25e86ee605643e27fe4811a78c;hp=fd4c939bd5869e19f7f6554d7e1834321c50a434;hb=6d686ea45f5cd01a0d11f92a903ac77779ad8562;hpb=dd9be86db6cde0afa5da0d1d1ac43b42e05dca26 diff --git a/test/dcp_playback_test.cc b/test/dcp_playback_test.cc index fd4c939bd..62c72cc84 100644 --- a/test/dcp_playback_test.cc +++ b/test/dcp_playback_test.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2018 Carl Hetherington + Copyright (C) 2018-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,49 +18,52 @@ */ -#include "lib/film.h" + #include "lib/butler.h" -#include "lib/player.h" #include "lib/dcp_content.h" +#include "lib/film.h" +#include "lib/player.h" #include "test.h" #include -using std::pair; -using std::shared_ptr; -using boost::optional; + +using std::make_shared; +using std::make_shared; #if BOOST_VERSION >= 106100 using namespace boost::placeholders; #endif using namespace dcpomatic; + /** Simulate the work that the player does, for profiling */ BOOST_AUTO_TEST_CASE (dcp_playback_test) { - shared_ptr film = new_test_film ("dcp_playback_test"); - shared_ptr content (new DCPContent(TestPaths::private_data() / "JourneyToJah_TLR-1_F_EN-DE-FR_CH_51_2K_LOK_20140225_DGL_SMPTE_OV")); + auto film = new_test_film ("dcp_playback_test"); + auto content = make_shared(TestPaths::private_data() / "JourneyToJah_TLR-1_F_EN-DE-FR_CH_51_2K_LOK_20140225_DGL_SMPTE_OV"); film->examine_and_add_content (content); BOOST_REQUIRE (!wait_for_jobs()); - shared_ptr butler ( - new Butler( - film, - shared_ptr(new Player(film)), - AudioMapping(6, 6), - 6, - bind(&PlayerVideo::force, _1, AV_PIX_FMT_RGB24), - VIDEO_RANGE_FULL, - false, - true) + auto butler = std::make_shared( + film, + make_shared(film, Image::Alignment::PADDED), + AudioMapping(6, 6), + 6, + boost::bind(&PlayerVideo::force, AV_PIX_FMT_RGB24), + VideoRange::FULL, + Image::Alignment::PADDED, + true, + false, + Butler::Audio::ENABLED ); - float* audio_buffer = new float[2000*6]; + + std::vector audio_buffer(2000 * 6); while (true) { - pair, DCPTime> p = butler->get_video (true, 0); + auto p = butler->get_video (Butler::Behaviour::BLOCKING, 0); if (!p.first) { break; } /* assuming DCP is 24fps/48kHz */ - butler->get_audio (audio_buffer, 2000); - p.first->image(bind(&PlayerVideo::force, _1, AV_PIX_FMT_RGB24), VIDEO_RANGE_FULL, false, true); + butler->get_audio (Butler::Behaviour::BLOCKING, audio_buffer.data(), 2000); + p.first->image(boost::bind(&PlayerVideo::force, AV_PIX_FMT_RGB24), VideoRange::FULL, true); } - delete[] audio_buffer; }