Merge remote-tracking branch 'origin/master' into 2.0
[dcpomatic.git] / src / lib / wscript
1 import os
2 import i18n
3
4 sources = """
5           analyse_audio_job.cc
6           audio_analysis.cc
7           audio_buffers.cc
8           audio_content.cc
9           audio_decoder.cc
10           audio_filter.cc
11           audio_mapping.cc
12           audio_processor.cc
13           cinema.cc
14           cinema_sound_processor.cc
15           colour_conversion.cc
16           config.cc
17           content.cc
18           content_factory.cc
19           content_subtitle.cc
20           cross.cc
21           dcp_content.cc
22           dcp_content_type.cc
23           dcp_decoder.cc
24           dcp_examiner.cc
25           dcp_subtitle_content.cc
26           dcp_subtitle_decoder.cc
27           dcp_video.cc
28           dcpomatic_time.cc
29           dolby_cp750.cc
30           encoder.cc
31           encoded_data.cc
32           examine_content_job.cc
33           exceptions.cc
34           file_group.cc
35           filter_graph.cc
36           ffmpeg.cc
37           ffmpeg_audio_stream.cc
38           ffmpeg_content.cc
39           ffmpeg_decoder.cc
40           ffmpeg_examiner.cc
41           ffmpeg_stream.cc
42           ffmpeg_subtitle_stream.cc
43           film.cc
44           filter.cc
45           frame_rate_change.cc
46           internet.cc
47           image.cc
48           image_content.cc
49           image_decoder.cc
50           image_examiner.cc
51           image_proxy.cc
52           isdcf_metadata.cc
53           j2k_image_proxy.cc
54           job.cc
55           job_manager.cc
56           kdm.cc
57           log.cc
58           magick_image_proxy.cc
59           md5_digester.cc
60           mid_side_decoder.cc
61           player.cc
62           player_video.cc
63           playlist.cc
64           ratio.cc
65           raw_image_proxy.cc
66           render_subtitles.cc
67           resampler.cc
68           safe_stringstream.cc
69           scp_dcp_job.cc
70           scaler.cc
71           send_kdm_email_job.cc
72           server.cc
73           server_finder.cc
74           single_stream_audio_content.cc
75           sndfile_content.cc
76           sndfile_decoder.cc
77           subrip.cc
78           subrip_content.cc
79           subrip_decoder.cc
80           subtitle_content.cc
81           subtitle_decoder.cc
82           timer.cc
83           transcode_job.cc
84           transcoder.cc
85           types.cc
86           ui_signaller.cc
87           update.cc
88           upmixer_a.cc
89           util.cc
90           video_content.cc
91           video_decoder.cc
92           writer.cc
93           """
94
95 def build(bld):
96     if bld.env.BUILD_STATIC:
97         obj = bld(features = 'cxx cxxstlib')
98     else:
99         obj = bld(features = 'cxx cxxshlib')
100
101     obj.name = 'libdcpomatic2'
102     obj.export_includes = ['..']
103     obj.uselib = """
104                  AVCODEC AVUTIL AVFORMAT AVFILTER SWSCALE SWRESAMPLE 
105                  BOOST_FILESYSTEM BOOST_THREAD BOOST_DATETIME BOOST_SIGNALS2
106                  SNDFILE OPENJPEG POSTPROC TIFF MAGICK SSH DCP CXML GLIB LZMA XML++
107                  CURL ZIP QUICKMAIL PANGOMM CAIROMM XMLSEC
108                  """
109
110     if bld.env.TARGET_OSX:
111         obj.framework = ['IOKit', 'Foundation']
112
113     obj.source = sources + ' version.cc'
114
115     if bld.env.TARGET_WINDOWS:
116         obj.uselib += ' WINSOCK2 BFD DBGHELP IBERTY SHLWAPI MSWSOCK BOOST_LOCALE'
117         obj.source += ' stack.cpp'
118     if bld.env.BUILD_STATIC:
119         obj.uselib += ' XMLPP'
120
121     obj.target = 'dcpomatic2'
122
123     i18n.po_to_mo(os.path.join('src', 'lib'), 'libdcpomatic2', bld)
124
125 def pot(bld):
126     i18n.pot(os.path.join('src', 'lib'), sources, 'libdcpomatic')
127
128 def pot_merge(bld):
129     i18n.pot_merge(os.path.join('src', 'lib'), 'libdcpomatic')