avdevice/decklink: fix MSVC build issues
Purpose: Made minor changes to get the decklink avdevice code to build using Visual C++. Notes: Made changes to configure per Hendrik Leppkes's review of first and second versions of patch. Also made slight alterations per Marton Balint's reviews. Comments: -- configure: Added if enabled decklink section and setting decklink_indev_extralibs and decklink_outdev_extralibs here for both mingw and Windows. Also eliminated the setting of these variables in the mingw section earlier in the file. -- libavdevice/decklink_common.cpp: Switched the order of the include of libavformat/internal.h to workaround build issues with Visual C++. See comment in file for more details. -- libavdevice/decklink_dec.cpp: a) Rearranged the include of libavformat/internal.h (for reasons as described above). b) Made slight alteration to an argument for call to av_rescale_q() to workaround a compiler error with Visual C++. This appears to only be an issue when building C++ files with Visual C++. See comment in code for more details. -- libavdevice/decklink_enc.cpp: Rearranged the include of libavformat/internal.h (for reasons as described above). Signed-off-by: Aaron Levinson <alevinsn@aracnet.com> Signed-off-by: Marton Balint <cus@passwd.hu>
This commit is contained in:
parent
f089e02fa2
commit
7f7ee86d5a
4 changed files with 35 additions and 6 deletions
|
@ -19,12 +19,17 @@
|
|||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
|
||||
/* Include internal.h first to avoid conflict between winsock.h (used by
|
||||
* DeckLink headers) and winsock2.h (used by libavformat) in MSVC++ builds */
|
||||
extern "C" {
|
||||
#include "libavformat/internal.h"
|
||||
}
|
||||
|
||||
#include <DeckLinkAPI.h>
|
||||
|
||||
extern "C" {
|
||||
#include "config.h"
|
||||
#include "libavformat/avformat.h"
|
||||
#include "libavformat/internal.h"
|
||||
#include "libavutil/avutil.h"
|
||||
#include "libavutil/common.h"
|
||||
#include "libavutil/imgutils.h"
|
||||
|
@ -262,8 +267,15 @@ static int64_t get_pkt_pts(IDeckLinkVideoInputFrame *videoFrame,
|
|||
res = videoFrame->GetHardwareReferenceTimestamp(time_base.den, &bmd_pts, &bmd_duration);
|
||||
break;
|
||||
case PTS_SRC_WALLCLOCK:
|
||||
pts = av_rescale_q(wallclock, AV_TIME_BASE_Q, time_base);
|
||||
{
|
||||
/* MSVC does not support compound literals like AV_TIME_BASE_Q
|
||||
* in C++ code (compiler error C4576) */
|
||||
AVRational timebase;
|
||||
timebase.num = 1;
|
||||
timebase.den = AV_TIME_BASE;
|
||||
pts = av_rescale_q(wallclock, timebase, time_base);
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (res == S_OK)
|
||||
pts = bmd_pts / time_base.num;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue