From 5e870e53c18ab62c173be03cc4ba665673e745ee Mon Sep 17 00:00:00 2001 From: nillerusr Date: Wed, 31 Mar 2021 20:12:00 +0300 Subject: [PATCH] add waf buildsystem --- .gitignore | 8 + appframework/wscript | 53 +++ bitmap/wscript | 61 +++ datacache/wscript | 52 +++ datamodel/wscript | 58 +++ devtools/makefile_base_posix.mak | 2 +- dmxloader/wscript | 52 +++ engine/voice_codecs/minimp3/wscript | 47 ++ engine/wscript | 346 ++++++++++++++ filesystem/wscript | 61 +++ gameui/wscript | 126 +++++ inputsystem/wscript | 52 +++ launcher/wscript | 50 ++ launcher_main/wscript | 43 ++ materialsystem/shaderapidx9/wscript | 75 +++ materialsystem/shaderlib/wscript | 51 +++ materialsystem/stdshaders/wscript | 167 +++++++ materialsystem/wscript | 77 ++++ mathlib/wscript | 69 +++ scenefilecache/wscript | 49 ++ scripts/continious_upload.sh | 15 + .../compiler_optimizations.cpython-39.pyc | Bin 0 -> 3741 bytes .../__pycache__/enforce_pic.cpython-39.pyc | Bin 0 -> 889 bytes .../__pycache__/xcompile.cpython-38.pyc | Bin 0 -> 12005 bytes .../__pycache__/xcompile.cpython-39.pyc | Bin 0 -> 12876 bytes .../__pycache__/xshlib.cpython-38.pyc | Bin 0 -> 5860 bytes .../__pycache__/xshlib.cpython-39.pyc | Bin 0 -> 5848 bytes scripts/waifulib/compiler_optimizations.py | 164 +++++++ scripts/waifulib/owcc.py | 124 +++++ scripts/waifulib/xcompile.py | 433 ++++++++++++++++++ scripts/waifulib/xshlib.py | 115 +++++ serverbrowser/wscript | 72 +++ soundemittersystem/wscript | 53 +++ studiorender/wscript | 60 +++ thirdparty | 2 +- tier0/wscript | 84 ++++ tier1/wscript | 92 ++++ tier2/wscript | 66 +++ tier3/wscript | 54 +++ togl/wscript | 63 +++ utils/bzip2/wscript | 56 +++ vgui2/matsys_controls/wscript | 67 +++ vgui2/src/wscript | 69 +++ vgui2/vgui_controls/wscript | 123 +++++ vgui2/vgui_surfacelib/wscript | 54 +++ vguimatsurface/wscript | 61 +++ video/wscript | 48 ++ vpklib/wscript | 49 ++ vstdlib/wscript | 57 +++ vtf/wscript | 51 +++ waf | 175 +++++++ wscript | 260 +++++++++++ 52 files changed, 3964 insertions(+), 2 deletions(-) create mode 100644 .gitignore create mode 100755 appframework/wscript create mode 100755 bitmap/wscript create mode 100755 datacache/wscript create mode 100755 datamodel/wscript create mode 100755 dmxloader/wscript create mode 100755 engine/voice_codecs/minimp3/wscript create mode 100755 engine/wscript create mode 100755 filesystem/wscript create mode 100755 gameui/wscript create mode 100755 inputsystem/wscript create mode 100755 launcher/wscript create mode 100755 launcher_main/wscript create mode 100755 materialsystem/shaderapidx9/wscript create mode 100755 materialsystem/shaderlib/wscript create mode 100644 materialsystem/stdshaders/wscript create mode 100755 materialsystem/wscript create mode 100755 mathlib/wscript create mode 100755 scenefilecache/wscript create mode 100644 scripts/continious_upload.sh create mode 100644 scripts/waifulib/__pycache__/compiler_optimizations.cpython-39.pyc create mode 100644 scripts/waifulib/__pycache__/enforce_pic.cpython-39.pyc create mode 100644 scripts/waifulib/__pycache__/xcompile.cpython-38.pyc create mode 100644 scripts/waifulib/__pycache__/xcompile.cpython-39.pyc create mode 100644 scripts/waifulib/__pycache__/xshlib.cpython-38.pyc create mode 100644 scripts/waifulib/__pycache__/xshlib.cpython-39.pyc create mode 100644 scripts/waifulib/compiler_optimizations.py create mode 100755 scripts/waifulib/owcc.py create mode 100644 scripts/waifulib/xcompile.py create mode 100644 scripts/waifulib/xshlib.py create mode 100755 serverbrowser/wscript create mode 100755 soundemittersystem/wscript create mode 100755 studiorender/wscript create mode 100755 tier0/wscript create mode 100755 tier1/wscript create mode 100755 tier2/wscript create mode 100755 tier3/wscript create mode 100755 togl/wscript create mode 100755 utils/bzip2/wscript create mode 100644 vgui2/matsys_controls/wscript create mode 100644 vgui2/src/wscript create mode 100644 vgui2/vgui_controls/wscript create mode 100644 vgui2/vgui_surfacelib/wscript create mode 100644 vguimatsurface/wscript create mode 100755 video/wscript create mode 100755 vpklib/wscript create mode 100755 vstdlib/wscript create mode 100755 vtf/wscript create mode 100755 waf create mode 100644 wscript diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..e483e125 --- /dev/null +++ b/.gitignore @@ -0,0 +1,8 @@ +*.mak +*.mak.vpc_crc +*.vpc_crc +*.a +*.project +lib/ +*obj_* +build/ diff --git a/appframework/wscript b/appframework/wscript new file mode 100755 index 00000000..26b2aa2a --- /dev/null +++ b/appframework/wscript @@ -0,0 +1,53 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'appframework' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'AppSystemGroup.cpp', + '../public/filesystem_init.cpp', +# 'vguimatsysapp.cpp' [$WIN32] +# 'winapp.cpp' [$WIN32] + 'posixapp.cpp',# [$POSIX] + 'sdlmgr.cpp'# [$SDL] +# 'glmrendererinfo_osx.mm' [$OSXALL] + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1' + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/bitmap/wscript b/bitmap/wscript new file mode 100755 index 00000000..83a358b1 --- /dev/null +++ b/bitmap/wscript @@ -0,0 +1,61 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'bitmap' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'ImageByteSwap.cpp', + 'colorconversion.cpp', + 'float_bm.cpp', + 'float_bm2.cpp', + 'float_bm3.cpp', + #'float_bm4.cpp', [$WINDOWS] + 'float_bm_bilateral_filter.cpp', + 'float_cube.cpp', + 'imageformat.cpp', + 'psd.cpp', + 'resample.cpp', + 'tgaloader.cpp', + 'tgawriter.cpp', + 'bitmap.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../thirdparty/stb' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/datacache/wscript b/datacache/wscript new file mode 100755 index 00000000..820f4d96 --- /dev/null +++ b/datacache/wscript @@ -0,0 +1,52 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'datacache' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'datacache.cpp', + 'mdlcache.cpp', + '../public/studio.cpp', + '../public/studio_virtualmodel.cpp', + '../common/studiobyteswap.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + + defines = [] + + libs = ['tier0','tier1','tier2','tier3'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/datamodel/wscript b/datamodel/wscript new file mode 100755 index 00000000..bd843d62 --- /dev/null +++ b/datamodel/wscript @@ -0,0 +1,58 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'datamodel' + +def options(opt): + return + +def configure(conf): + conf.define('DATAMODEL_LIB',1) + +def build(bld): + source = [ + 'clipboardmanager.cpp', + 'datamodel.cpp', + 'dependencygraph.cpp', + 'dmattribute.cpp', + 'dmelement.cpp', + 'dmelementdictionary.cpp', + 'dmelementfactoryhelper.cpp', + 'DmElementFramework.cpp', + 'dmserializerbinary.cpp', + 'dmserializerkeyvalues.cpp', + 'dmserializerkeyvalues2.cpp', + 'undomanager.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/devtools/makefile_base_posix.mak b/devtools/makefile_base_posix.mak index 21791b08..dca45b89 100644 --- a/devtools/makefile_base_posix.mak +++ b/devtools/makefile_base_posix.mak @@ -116,7 +116,7 @@ COPY_DLL_TO_SRV = 0 # We should always specify -Wl,--build-id, as documented at: # http://linux.die.net/man/1/ld and http://fedoraproject.org/wiki/Releases/FeatureBuildId.http://fedoraproject.org/wiki/Releases/FeatureBuildId -LDFLAGS += -Wl,--build-id -fsanitize=address -fsanitize=undefined +LDFLAGS += -Wl,--build-id # # If we should be running in a chroot, check to see if we are. If not, then prefix everything with the diff --git a/dmxloader/wscript b/dmxloader/wscript new file mode 100755 index 00000000..9da0a98d --- /dev/null +++ b/dmxloader/wscript @@ -0,0 +1,52 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'dmxloader' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('DMXLOADER_LIB',1) + +def build(bld): + source = [ + 'dmxattribute.cpp', + 'dmxelement.cpp', + 'dmxloader.cpp', + 'dmxloadertext.cpp', + 'dmxserializationdictionary.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/engine/voice_codecs/minimp3/wscript b/engine/voice_codecs/minimp3/wscript new file mode 100755 index 00000000..722693a7 --- /dev/null +++ b/engine/voice_codecs/minimp3/wscript @@ -0,0 +1,47 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'vaudio_minimp3' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'mp3codecs.cpp', + ] + + includes = [ + '.', + '../../../public/tier1', + '../../../public/', + '../../../thirdparty/minimp3' + ] + + defines = [] + + libs = ['tier0','tier1','vstdlib'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/engine/wscript b/engine/wscript new file mode 100755 index 00000000..7c2a286d --- /dev/null +++ b/engine/wscript @@ -0,0 +1,346 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'engine' + +def options(opt): + # stub + return + +def configure(conf): + conf.env.append_unique('DEFINES',[ + '__USEA3D', + '_ADD_EAX_', + 'ENGINE_DLL', + 'VERSION_SAFE_STEAM_API_INTERFACES', + 'USE_BREAKPAD_HANDLER' + ]) + +def build(bld): + source = [ + 'client_pch.cpp', ##[!$DEDICATED] + 'cl_rcon.cpp', ##[!$DEDICATED] + 'socketcreator.cpp', + 'rpt_engine.cpp', ##[!$DEDICATED] + 'cl_steamauth.cpp',# #[!$DEDICATED] + 'clientframe.cpp', + 'decal_clip.cpp', + 'demofile.cpp', + 'DevShotGenerator.cpp', + 'OcclusionSystem.cpp', + 'tmessage.cpp', + 'r_efx.cpp',# #[!$DEDICATED] + 'view.cpp', ##[!$DEDICATED] + 'baseclient.cpp', + 'baseclientstate.cpp', + 'cbenchmark.cpp', + 'cdll_engine_int.cpp', ##[!$DEDICATED] / + 'cl_main.cpp',##[!$DEDICATED] / + 'cl_demo.cpp',##[!$DEDICATED] / + #'cl_null.cpp', [$DEDICATED] / + 'cl_demoaction.cpp', #[!$DEDICATED] / + 'cl_demoaction_types.cpp', #[!$DEDICATED] / + 'cl_demoactioneditors.cpp', #[!$DEDICATED] / + 'cl_demoactionmanager.cpp', #[!$DEDICATED] / + 'cl_demoeditorpanel.cpp', #[!$DEDICATED] / + 'cl_demosmootherpanel.cpp', #[!$DEDICATED] / + 'cl_demouipanel.cpp', #[!$DEDICATED] / + 'cl_foguipanel.cpp', #[!$DEDICATED] / + 'cl_txviewpanel.cpp', #[!$DEDICATED] / + 'cl_entityreport.cpp', #[!$DEDICATED] / + 'cl_ents_parse.cpp', #[!$DEDICATED] / + 'cl_localnetworkbackdoor.cpp', #[!$DEDICATED] / + 'cl_parse_event.cpp', #[!$DEDICATED] / + 'cl_pluginhelpers.cpp',#[!$DEDICATED] / + 'cl_pred.cpp', #[!$DEDICATED] / + 'cl_texturelistpanel.cpp', #[!$DEDICATED] / + 'client.cpp',#[!$DEDICATED] / + 'colorcorrectionpanel.cpp', #[!$DEDICATED] / + 'console.cpp', + 'render_pch.cpp', + + 'buildcubemaps.cpp', #[!$DEDICATED] / + 'debug_leafvis.cpp', #[!$DEDICATED] / + 'debugoverlay.cpp', #[!$DEDICATED] / + 'decals.cpp', + 'disp.cpp', + 'disp_interface.cpp', + 'disp_mapload.cpp', + 'gl_draw.cpp', + 'gl_rsurf.cpp', + 'gl_shader.cpp', + 'gl_drawlights.cpp', #[!$DEDICATED] / + 'gl_lightmap.cpp', #[!$DEDICATED] / + 'gl_matsysiface.cpp', #[!$DEDICATED] / + 'gl_rlight.cpp',#[!$DEDICATED] / + 'gl_rmain.cpp',#[!$DEDICATED] / + 'gl_rmisc.cpp',#[!$DEDICATED] / + 'gl_screen.cpp',#[!$DEDICATED] / + 'gl_warp.cpp',#[!$DEDICATED] / + 'l_studio.cpp', + 'matsys_interface.cpp', + 'modelloader.cpp', + 'Overlay.cpp', + 'r_areaportal.cpp', #[!$DEDICATED] / + 'r_decal.cpp', + 'r_linefile.cpp', + 'shadowmgr.cpp',#[!$DEDICATED] + 'server_pch.cpp', + + + 'sv_ipratelimit.cpp', + 'sv_rcon.cpp', + 'sv_steamauth.cpp', + 'sv_uploaddata.cpp', + 'sv_uploadgamestats.cpp', + 'vengineserver_impl.cpp', + + 'sv_main.cpp', + 'sv_client.cpp', + 'sv_ents_write.cpp', + 'sv_filter.cpp', + 'sv_framesnapshot.cpp', + 'sv_log.cpp', + 'sv_packedentities.cpp', + 'sv_plugin.cpp', + 'sv_precache.cpp', + 'sv_redirect.cpp', + 'sv_remoteaccess.cpp', + + 'baseautocompletefilelist.cpp', + 'baseserver.cpp', + 'bitbuf_errorhandler.cpp', + '../public/blockingudpsocket.cpp', + '../public/bsptreedata.cpp', + '../public/builddisp.cpp', + 'changeframelist.cpp', + 'checksum_engine.cpp', + 'ccs.cpp', + 'clockdriftmgr.cpp', + 'cl_bounded_cvars.cpp', ##[!$DEDICATED] + 'cl_check_process.cpp', + 'cmd.cpp', + 'cmodel.cpp', + 'cmodel_bsp.cpp', + 'cmodel_disp.cpp', + '../public/collisionutils.cpp', + 'common.cpp', + '../public/crtmemdebug.cpp', + 'cvar.cpp', + '../public/disp_common.cpp', + 'disp_defs.cpp', + 'disp_helpers.cpp', + '../public/disp_powerinfo.cpp', + '../public/dispcoll_common.cpp', + 'DownloadListGenerator.cpp', + 'downloadthread.cpp', ##[!$DEDICATED] + 'dt.cpp', + 'dt_common_eng.cpp', + 'dt_encode.cpp', + 'dt_instrumentation.cpp', + 'dt_instrumentation_server.cpp', + 'dt_localtransfer.cpp', + '../public/dt_recv.cpp', + 'dt_recv_decoder.cpp', + 'dt_recv_eng.cpp', + '../public/dt_send.cpp', + 'dt_send_eng.cpp', + 'dt_stack.cpp', + 'dt_test.cpp', + '../public/dt_utlvector_common.cpp', + '../public/dt_utlvector_recv.cpp', + '../public/dt_utlvector_send.cpp', + 'enginesingleuserfilter.cpp', + 'enginestats.cpp', + 'enginethreads.cpp', + 'enginetrace.cpp', + 'filesystem_engine.cpp', + '../public/filesystem_helpers.cpp', + '../public/filesystem_init.cpp', + 'filetransfermgr.cpp', + 'GameEventManager.cpp', + 'GameEventManagerOld.cpp', + 'gametrace_engine.cpp', + 'hltvclient.cpp', + 'hltvclientstate.cpp', + 'hltvdemo.cpp', + 'hltvserver.cpp', + 'hltvtest.cpp', + 'host.cpp', + 'host_cmd.cpp', + 'host_listmaps.cpp', + 'host_phonehome.cpp', + 'host_state.cpp', + 'initmathlib.cpp', + '../common/language.cpp', + 'LocalNetworkBackdoor.cpp', + 'LoadScreenUpdate.cpp', #[!$DEDICATED] + '../public/lumpfiles.cpp', + 'MapReslistGenerator.cpp', + 'matchmakinghost.cpp', #[!$DEDICATED] + 'matchmakingqos.cpp', #[!$DEDICATED] + 'matchmakingclient.cpp', #[!$DEDICATED] + 'matchmakingshared.cpp', #[!$DEDICATED] + 'matchmakingmigrate.cpp', #[!$DEDICATED] + 'materialproxyfactory.cpp', + 'mem_fgets.cpp', + 'mod_vis.cpp', + 'ModelInfo.cpp', + 'net_chan.cpp', + 'net_synctags.cpp', + 'net_ws.cpp', + 'net_ws_queued_packet_sender.cpp', + '../common/netmessages.cpp', + '../common/steamid.cpp', + 'networkstringtable.cpp', + 'NetworkStringTableItem.cpp', + 'networkstringtableserver.cpp', + '../public/networkvar.cpp', + 'packed_entity.cpp', + 'pure_server.cpp', + 'pr_edict.cpp', + 'precache.cpp', + 'quakedef.cpp', + 'randomstream.cpp', + '../common/randoverride.cpp', + '../public/registry.cpp', + 'engine_replay_int.cpp', + 'replay_internal.cpp', + 'replaydemo.cpp', + 'replaydemoplayer.cpp', #[!$DEDICATED] + 'replayserver.cpp', + '../public/sentence.cpp', + 'Session.cpp', #[!$DEDICATED] + 'sound_shared.cpp', + 'spatialpartition.cpp', + 'staticpropmgr.cpp', + '../public/studio.cpp', + 'sys_dll.cpp', + 'sys_dll2.cpp', + 'sys_engine.cpp', + 'sys_mainwind.cpp', #[!$DEDICATED] + 'sys_linuxwind.cpp', #[$POSIX] + 'testscriptmgr.cpp', + 'traceinit.cpp', + '../public/vallocator.cpp', + 'voiceserver_impl.cpp', + 'vprof_engine.cpp', + 'vprof_record.cpp', + 'world.cpp', + '../public/XZip.cpp', + '../public/XUnzip.cpp', + 'zone.cpp', + 'bugreporter.cpp', #[!$DEDICATED] + 'cheatcodes.cpp', + 'download.cpp', #[!$DEDICATED] + '../public/editor_sendcommand.cpp', + 'host_saverestore.cpp', #[!$DEDICATED] + 'keys.cpp', + 'lightcache.cpp', #[!$DEDICATED] + 'networkstringtableclient.cpp', + 'saverestore_filesystem.cpp', #[!$DEDICATED] + '../public/scratchpad3d.cpp', + 'servermsghandler.cpp', + 'sys_getmodes.cpp', #[!$DEDICATED] + 'vgui_askconnectpanel.cpp', #[!$DEDICATED] + 'xboxsystem.cpp', #[!$DEDICATED] + '../common/SourceAppInfo.cpp', + 'snd_io.cpp', + 'EngineSoundServer.cpp', + 'EngineSoundClient.cpp', #[!$DEDICATED] + 'engsoundservice.cpp', #[!$DEDICATED] + 'audio/private/voice_wavefile.cpp', + 'audio/private/MPAFile.cpp', #[!$DEDICATED&&!$X360] + 'audio/private/MPAHeader.cpp', #[!$DEDICATED&&!$X360] + 'audio/private/circularbuffer.cpp', #[!$DEDICATED] + 'audio/private/snd_posix.cpp', # [$POSIX] + + 'audio/audio_pch.cpp', #[!$DEDICATED] + + 'audio/private/vox.cpp', + 'audio/private/snd_dev_common.cpp', #[!$DEDICATED] / + 'audio/private/snd_dma.cpp', #[!$DEDICATED] / + 'audio/private/snd_dsp.cpp', #[!$DEDICATED] / + 'audio/private/snd_mix.cpp', #[!$DEDICATED] / + 'audio/private/snd_sentence_mixer.cpp', #[!$DEDICATED]/ + 'audio/private/snd_wave_data.cpp', #[!$DEDICATED] / + 'audio/private/snd_wave_mixer.cpp', #[!$DEDICATED] / + 'audio/private/snd_wave_mixer_adpcm.cpp', #[!$DEDICATED] / + 'audio/private/snd_wave_source.cpp', #[!$DEDICATED] / + 'audio/private/snd_wave_temp.cpp', #[!$DEDICATED] / + 'audio/private/snd_win.cpp', #[!$DEDICATED] / + 'audio/private/voice_gain.cpp', + + #'audio/private/snd_dev_direct.cpp', [$WINDOWS]/ + #'audio/private/snd_dev_wave.cpp', [$WINDOWS]/ + 'audio/private/snd_mp3_source.cpp', #[!$DEDICATED]/ + 'audio/private/snd_wave_mixer_mp3.cpp', #[!$DEDICATED] / + 'audio/private/VBRHeader.cpp', # [!$DEDICATED&&!$X360]/ + 'audio/private/voice.cpp', #[!$DEDICATED&&!$X360]/ + #'audio/private/voice_mixer_controls.cpp', [$WINDOWS] / + #'audio/private/voice_record_dsound.cpp', [$WINDOWS] / + 'audio/private/voice_sound_engine_interface.cpp', #[!$DEDICATED&&!$X360] + + #'audio/private/snd_dev_xaudio.cpp',[$X360] + #'audio/private/snd_wave_mixer_xma.cpp', [$X360] + + 'audio/private/snd_dev_sdl.cpp', #[$SDL && !$OSXALL] + #'audio/private/snd_dev_openal.cpp', # [$OSXALL] + #'audio/private/snd_dev_mac_audioqueue.cpp',# [$OSXALL] + 'audio/private/voice_mixer_controls_openal.cpp', #[$OSXALL||($LINUXALL&&!$DEDICATED)] + 'audio/private/voice_record_openal.cpp', #[$OSXALL||($LINUXALL&&!$DEDICATED)] + #'audio/private/voice_record_mac_audioqueue.cpp', #[$OSXALL] + + '../public/vgui_controls/vgui_controls.cpp', + '../common/vgui/vgui_basebudgetpanel.cpp', + '../common/vgui/vgui_budgetbargraphpanel.cpp', + '../common/vgui/vgui_budgethistorypanel.cpp', + '../common/vgui/vgui_budgetpanelshared.cpp', + 'perfuipanel.cpp', + 'vgui_basepanel.cpp', + 'vgui_baseui_interface.cpp', + 'vgui_budgetpanel.cpp', + 'vgui_DebugSystemPanel.cpp', + 'vgui_drawtreepanel.cpp', + 'vgui_helpers.cpp', + 'vgui_texturebudgetpanel.cpp', + 'vgui_vprofgraphpanel.cpp', + 'vgui_vprofpanel.cpp', + 'enginetool.cpp', #[!$DEDICATED] + 'toolframework.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common', + 'audio', + 'audio/public', + 'audio/private' + ] + + defines = [] + + libs = ['tier0','vgui_controls','dmxloader','tier1','tier2','tier3','bitmap','vstdlib','appframework','datamodel','vtf','mathlib','steam_api','matsys_controls','BZIP2','SDL2','JPEG','ZLIB','OPENAL','CURL'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/filesystem/wscript b/filesystem/wscript new file mode 100755 index 00000000..ceadcdb8 --- /dev/null +++ b/filesystem/wscript @@ -0,0 +1,61 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'filesystem_stdio' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('FILESYSTEM_STDIO_EXPORTS',1) + conf.define('DONT_PROTECT_FILEIO_FUNCTIONS',1) +# conf.define('PROTECTED_THINGS_ENABLE',1) + conf.define('_USE_32BIT_TIME_T',1) + conf.define('SUPPORT_PACKED_STORE',1) + +def build(bld): + source = [ + 'basefilesystem.cpp', + 'packfile.cpp', + 'filetracker.cpp', + 'filesystem_async.cpp', + 'filesystem_stdio.cpp', + '../public/kevvaluescompiler.cpp', + '../public/zip_utils.cpp', + 'QueuedLoader.cpp', + 'linux_support.cpp', # [$POSIX] + '../public/tier0/memoverride.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + + defines = [] + + libs = ['tier0','tier1','tier2','vstdlib','vpklib'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/gameui/wscript b/gameui/wscript new file mode 100755 index 00000000..dedcb95c --- /dev/null +++ b/gameui/wscript @@ -0,0 +1,126 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'GameUI' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('GAMEUI_EXPORTS',1) + conf.define('VERSION_SAFE_STEAM_API_INTERFACES',1) + +def build(bld): + source = [ + 'BackgroundMenuButton.cpp', + 'BasePanel.cpp', + 'GameConsole.cpp', + 'GameUI_Interface.cpp', + # 'LogoFile.cpp', [!$POSIX] + 'ModInfo.cpp', + 'MouseMessageForwardingPanel.cpp', + '../common/GameUI/ObjectList.cpp', + 'PanelListPanel.cpp', + 'RunGameEngine.cpp', + '../common/GameUI/scriptobject.cpp', + 'Sys_Utils.cpp', + 'TextEntryBox.cpp', + 'TGAImagePanel.cpp', + '../public/vgui_controls/vgui_controls.cpp', + 'VGuiSystemModuleLoader.cpp', + 'BonusMapsDatabase.cpp', + '../common/language.cpp', + '../common/imageutils.cpp', + 'SaveGameBrowserDialog.cpp', + 'gameui_util.cpp', + 'BitmapImagePanel.cpp', + 'CommandCheckButton.cpp', + 'CvarNegateCheckButton.cpp', + '../common/GameUI/cvarslider.cpp', + 'CvarTextEntry.cpp', + 'CvarToggleCheckButton.cpp', + 'HapticControlBox.cpp', + 'KeyToggleCheckButton.cpp', + 'LabeledCommandComboBox.cpp', + 'URLButton.cpp', + 'vcontrolslistpanel.cpp', + 'BenchmarkDialog.cpp', + 'BonusMapsDialog.cpp', + 'CommentaryDialog.cpp', + 'CommentaryExplanationDialog.cpp', + 'ContentControlDialog.cpp', + 'CustomTabExplanationDialog.cpp', + 'GameConsoleDialog.cpp', + 'LoadGameDialog_Xbox.cpp', + 'LoadGameDialog.cpp', + 'MultiplayerAdvancedDialog.cpp', + 'NewGameDialog.cpp', + 'PlayerListDialog.cpp', + 'SaveGameDialog_Xbox.cpp', + 'SaveGameDialog.cpp', + 'LoadCommentaryDialog.cpp', + 'LoadingDialog.cpp', + 'BaseSaveGameDialog.cpp', + #'ChangeGameDialog.cpp', [!$POSIX] + 'CreateMultiplayerGameBotPage.cpp', + 'CreateMultiplayerGameDialog.cpp', + 'CreateMultiplayerGameGameplayPage.cpp', + 'CreateMultiplayerGameServerPage.cpp', + 'OptionsDialog_Xbox.cpp', + 'ControllerDialog.cpp', + 'matchmaking/achievementsdialog.cpp', + 'matchmaking/basedialog.cpp', + 'matchmaking/dialogmenu.cpp', + 'matchmaking/leaderboarddialog.cpp', + 'matchmaking/matchmakingbasepanel.cpp', + 'matchmaking/pausedialog.cpp', + 'matchmaking/sessionlobbydialog.cpp', + 'matchmaking/sessionoptionsdialog.cpp', + 'matchmaking/sessionbrowserdialog.cpp', + 'matchmaking/welcomedialog.cpp', + 'OptionsDialog.cpp', + 'OptionsSubAudio.cpp', + 'OptionsSubDifficulty.cpp', + 'OptionsSubGame.cpp', + #'OptionsSubHaptics.cpp', [$WIN32] [$WIN32] + 'OptionsSubKeyboard.cpp', + 'OptionsSubMouse.cpp', + 'OptionsSubMultiplayer.cpp', + 'OptionsSubPortal.cpp', + 'OptionsSubVideo.cpp', + 'OptionsSubVoice.cpp', + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common', + '../common/GameUI' + ] + + defines = [] + + libs = ['tier0','vgui_controls','tier1','tier2','tier3','vstdlib','vtf','bitmap','mathlib','SDL2','steam_api','matsys_controls','JPEG','PNG'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/inputsystem/wscript b/inputsystem/wscript new file mode 100755 index 00000000..4441a012 --- /dev/null +++ b/inputsystem/wscript @@ -0,0 +1,52 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'inputsystem' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('VERSION_SAFE_STEAM_API_INTERFACES',1) + +def build(bld): + source = [ + 'inputsystem.cpp', + 'joystick_sdl.cpp', + #'novint.cpp', # [$WIN32] + 'key_translation.cpp', + 'steamcontroller.cpp' + ] + + includes = [ + '.', + '../common', + '../public', + '../public/tier0', + '../thirdparty/SDL2' + ] + + defines = [] + + libs = ['tier0','tier1','tier2','vstdlib','SDL2','steam_api'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/launcher/wscript b/launcher/wscript new file mode 100755 index 00000000..6fac8ff4 --- /dev/null +++ b/launcher/wscript @@ -0,0 +1,50 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'launcher' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('LAUNCHERONLY',1) + +def build(bld): + source = [ + '../public/filesystem_init.cpp', + 'launcher.cpp', + 'reslistgenerator.cpp', + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = ['tier0','tier1','tier2','tier3','vstdlib','steam_api','appframework','SDL2','togl'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/launcher_main/wscript b/launcher_main/wscript new file mode 100755 index 00000000..fd66e858 --- /dev/null +++ b/launcher_main/wscript @@ -0,0 +1,43 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'hl2' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + + source = ['main.cpp'] + includes = ['../public'] + defines = [] + libs = [] + + if bld.env.DEST_OS != 'win32': + libs += [ 'DL' ] + else: + libs += ['USER32', 'SHELL32'] + source += ['launcher_main.rc'] + + install_path = bld.env.PREFIX + bld( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx cxxprogram', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/materialsystem/shaderapidx9/wscript b/materialsystem/shaderapidx9/wscript new file mode 100755 index 00000000..771519d5 --- /dev/null +++ b/materialsystem/shaderapidx9/wscript @@ -0,0 +1,75 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'shaderapidx9' + +def options(opt): + # stub + return + +def configure(conf): + conf.env.append_unique('DEFINES',[ + 'SHADERAPIDX9', + 'SHADER_DLL_EXPORT', + 'PROTECTED_THINGS_ENABLE', + 'strncpy=use_Q_strncpy_instead', + '_snprintf=use_Q_snprintf_instead', + 'GL_GLEXT_PROTOTYPES', + 'DX_TO_GL_ABSTRACTION' + ]) + +def build(bld): + source = [ + 'colorformatdx8.cpp', + '../../public/filesystem_helpers.cpp', + 'hardwareconfig.cpp', + 'meshbase.cpp', + 'meshdx8.cpp', + #'recording.cpp', [$WIN32 && !$GL] + 'shaderapidx8.cpp', + 'shaderdevicebase.cpp', + 'shaderapibase.cpp', + 'shaderdevicedx8.cpp', + 'shadershadowdx8.cpp', + 'texturedx8.cpp', + 'TransitionTable.cpp', + 'cvballoctracker.cpp', + 'vertexdecl.cpp', + 'vertexshaderdx8.cpp', + #'wmi.cpp', [$WIN32 && !$GL] + #'textureheap.cpp', [$X360] + 'winutils.cpp'# [!$WIN32] + ] + + includes = [ + '.', + '../../public', + '../../public/tier0', + '../../public/tier1', + '../../common', + '../' + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = ['tier0','tier1','tier2','vstdlib','togl','bitmap','mathlib'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/materialsystem/shaderlib/wscript b/materialsystem/shaderlib/wscript new file mode 100755 index 00000000..4f758024 --- /dev/null +++ b/materialsystem/shaderlib/wscript @@ -0,0 +1,51 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'shaderlib' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('FAST_MATERIALVAR_ACCESS',1) + +def build(bld): + source = [ + 'BaseShader.cpp', + 'ShaderDLL.cpp', + 'shaderlib_cvar.cpp' + ] + + includes = [ + '.', + '../../public', + '../../public/tier0', + '../../public/tier1', + '../../common', + '../' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/materialsystem/stdshaders/wscript b/materialsystem/stdshaders/wscript new file mode 100644 index 00000000..ecf1c982 --- /dev/null +++ b/materialsystem/stdshaders/wscript @@ -0,0 +1,167 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'stdshader_dx9' + +def options(opt): + # stub + return + +def configure(conf): + conf.env.append_unique('DEFINES',[ + 'STDSHADER_DX9_DLL_EXPORT', + 'FAST_MATERIALVAR_ACCESS' + ]) + +def build(bld): + source = [ + 'aftershock.cpp', + 'aftershock_helper.cpp', + 'AccumBuff4Sample.cpp', + 'accumbuff5sample.cpp', + 'BaseVSShader.cpp', + 'bik_dx90.cpp', + 'Bloom.cpp', + 'BlurFilterX.cpp', + 'BlurFilterY.cpp', + 'BufferClearObeyStencil_dx9.cpp', + 'cable_dx9.cpp', + 'cloak.cpp', + 'cloak_blended_pass_helper.cpp', + 'cloak_dx9_helper.cpp', + 'cloud_dx9.cpp', + 'colorcorrection.cpp', + 'compositor.cpp', + 'core_dx9.cpp', + 'color_projection.cpp', + 'debugmrttexture.cpp', + #'debugmorphaccumulator_dx9.cpp', [$WIN32] + 'DebugTextureView.cpp', + 'DecalBaseTimesLightmapAlphaBlendSelfIllum_dx9.cpp', + 'DecalModulate_dx9.cpp', + 'depthwrite.cpp', + 'Downsample.cpp', + 'downsample_nohdr.cpp', + 'Engine_Post_dx9.cpp', + 'emissive_scroll_blended_pass_helper.cpp', + 'eye_refract.cpp', + 'eye_refract_helper.cpp', + 'eyes_dx8_dx9_helper.cpp', + 'eyes_dx9.cpp', + 'eyeglint_dx9.cpp', + 'filmdust_dx8_dx9.cpp', + 'filmgrain_dx8_dx9.cpp', + 'flesh_interior_blended_pass_helper.cpp', + 'floatcombine.cpp', + 'floatcombine_autoexpose.cpp', + 'floattoscreen.cpp', + 'floattoscreen_vanilla.cpp', + 'HDRCombineTo16Bit.cpp', + 'HDRSelectRange.cpp', + 'hsl_filmgrain_pass1.cpp', + 'hsl_filmgrain_pass2.cpp', + 'hsv.cpp', + 'introscreenspaceeffect.cpp', + 'lightmappedgeneric_dx9.cpp', + 'lightmappedgeneric_dx9_helper.cpp', + 'lightmappedreflective.cpp', + 'modulate_dx9.cpp', + 'MonitorScreen_dx9.cpp', + #'morphaccumulate_dx9.cpp', [$WIN32] + #'morphweight_dx9.cpp', [$WIN32] + 'motion_blur_dx9.cpp', + 'occlusion_dx9.cpp', + 'particlelitgeneric_dx9.cpp', + 'particlelitgeneric_dx9_helper.cpp', + 'particlesphere_dx9.cpp', + 'portal.cpp', + 'portalstaticoverlay.cpp', + 'portal_refract.cpp', + 'portal_refract_helper.cpp', + 'pyro_vision.cpp', + 'refract.cpp', + 'refract_dx9_helper.cpp', + #'rendertargetblit_x360.cpp', [$X360] + 'sample4x4.cpp', + 'sample4x4_blend.cpp', + 'screenspace_general.cpp', + 'sfm_blurfilterx.cpp', + 'sfm_blurfiltery.cpp', + 'sfm_downsample.cpp', + 'sfm_integercombine.cpp', + 'shadow.cpp', + 'shadowbuild_dx9.cpp', + 'shadowmodel_dx9.cpp', + 'shatteredglass.cpp', + 'showz.cpp', + 'skin_dx9_helper.cpp', + 'sky_dx9.cpp', + 'sky_hdr_dx9.cpp', + 'sprite_dx9.cpp', + 'spritecard.cpp', + 'teeth.cpp', + 'TreeLeaf.cpp', + 'unlitgeneric_dx9.cpp', + 'unlittwotexture_dx9.cpp', + 'vertexlitgeneric_dx9.cpp', + 'vertexlitgeneric_dx9_helper.cpp', + 'volume_clouds.cpp', + 'volume_clouds_helper.cpp', + 'vortwarp_dx9.cpp', + 'vr_distort_hud.cpp', + 'vr_distort_texture.cpp', + 'warp.cpp', + 'water.cpp', + 'weapon_sheen_pass_helper.cpp', + 'windowimposter_dx90.cpp', + 'wireframe_dx9.cpp', + 'worldtwotextureblend.cpp', + 'worldvertexalpha.cpp', + 'worldvertextransition.cpp', + 'worldvertextransition_dx8_helper.cpp', + 'writez_dx9.cpp', + 'writestencil_dx9.cpp', + 'eyeball.cpp' +# $Folder 'stdshader_dbg Files', [$X360] +# { +# 'debugdepth.cpp', +# 'DebugDrawEnvmapMask.cpp', +# 'debugluxel.cpp', +# 'debugnormalmap.cpp', +# 'debugtangentspace.cpp', +# 'fillrate.cpp', + + ] + + includes = [ + '.', + '../../public', + '../../public/tier0', + '../../public/tier1', + 'fxctmp9', + 'vshtmp9' + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = ['tier0','shaderlib','tier1','mathlib'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/materialsystem/wscript b/materialsystem/wscript new file mode 100755 index 00000000..3daa0639 --- /dev/null +++ b/materialsystem/wscript @@ -0,0 +1,77 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'materialsystem' + +def options(opt): + # stub + return + +def configure(conf): + conf.env.append_unique('DEFINES',[ + 'DEFINE_MATERIALSYSTEM_INTERFACE', + 'MATERIALSYSTEM_EXPORTS', + 'PROTECTED_THINGS_ENABLE', + 'strncpy=use_Q_strncpy_instead', + '_snprintf=use_Q_snprintf_instead' + ]) + +def build(bld): + source = [ + 'CColorCorrection.cpp', + 'cmaterial.cpp', + 'cmaterial_queuefriendly.cpp', + 'CMaterialSubRect.cpp', + 'cmaterialvar.cpp', + 'cmatnullrendercontext.cpp', + 'colorspace.cpp', + 'ctexture.cpp', + '../public/filesystem_helpers.cpp', + 'imagepacker.cpp', + 'mat_stub.cpp', + 'materialsystem_global.cpp', + 'morph.cpp', + 'occlusionquerymgr.cpp', + 'shadersystem.cpp', + 'texturemanager.cpp', + 'pch_materialsystem.cpp', + 'cmaterialdict.cpp', + 'cmaterialsystem.cpp', + 'cmatlightmaps.cpp', + 'cmatrendercontext.cpp', + 'cmatqueuedrendercontext.cpp', + 'ctexturecompositor.cpp' + ] + + includes = [ + '.', + '../../public', + '../../public/tier0', + '../../public/tier1', + '../../common', + '../' + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = ['tier0','tier1','tier2','vstdlib','mathlib','bitmap','shaderlib','vtf'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/mathlib/wscript b/mathlib/wscript new file mode 100755 index 00000000..2b3ed24d --- /dev/null +++ b/mathlib/wscript @@ -0,0 +1,69 @@ + #! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'mathlib' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('MATHLIB_LIB',1) + +def build(bld): + source = [ + 'color_conversion.cpp', + 'halton.cpp', + 'lightdesc.cpp', + 'mathlib_base.cpp', + 'powsse.cpp', + 'sparse_convolution_noise.cpp', + 'sseconst.cpp', + 'sse.cpp', # [$WINDOWS||$POSIX] + 'ssenoise.cpp', + '3dnow.cpp', # [$WINDOWS||$LINUX] + 'anorms.cpp', + 'bumpvects.cpp', + 'IceKey.cpp', + 'imagequant.cpp', + 'polyhedron.cpp', + 'quantize.cpp', + 'randsse.cpp', + 'spherical.cpp', + 'simdvectormatrix.cpp', + 'vector.cpp', + 'vmatrix.cpp', + 'almostequal.cpp' + ] + + includes = [ + '.', + '../common', + '../public', + '../public/tier0', + '../public/mathlib' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/scenefilecache/wscript b/scenefilecache/wscript new file mode 100755 index 00000000..b59c2f3a --- /dev/null +++ b/scenefilecache/wscript @@ -0,0 +1,49 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'scenefilecache' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('_WINDOWS',1) # WTF? this defined in original vpc file + conf.define('PROTECTED_THINGS_ENABLE',1) + +def build(bld): + source = [ + 'SceneFileCache.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../game/shared' + ] + + defines = [] + + libs = ['tier0','tier1'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/scripts/continious_upload.sh b/scripts/continious_upload.sh new file mode 100644 index 00000000..1301102f --- /dev/null +++ b/scripts/continious_upload.sh @@ -0,0 +1,15 @@ +################################## +# +# GitHub Releases +# +################################## + +set +x + +# Disabled until GitHub sends prereleases to email + +wget -O upload.sh "https://raw.githubusercontent.com/FWGS/uploadtool/master/upload.sh" +chmod +x upload.sh + +export GITHUB_TOKEN=$GH_TOKEN +./upload.sh $* diff --git a/scripts/waifulib/__pycache__/compiler_optimizations.cpython-39.pyc b/scripts/waifulib/__pycache__/compiler_optimizations.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1dc9038b94fbeb10ef18c69a2fbc9e00be876da2 GIT binary patch literal 3741 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 YKN<_!oCY*$Zh9N<45L^n&T8s^0r_YM3;+NC literal 0 HcmV?d00001 diff --git a/scripts/waifulib/__pycache__/enforce_pic.cpython-39.pyc b/scripts/waifulib/__pycache__/enforce_pic.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4c8fad24908b93eab063bfa1b97a842b763e8d78 GIT binary patch literal 889 zcmah{&2G~`5Z+zev4ffte$^*HvP5f%-Vj0*ry!&fkX)q7m*9HWjZK5!8FrNJgy0A2vg#~>)8xIjZ3 zV~i-F)+LGwwW$MNi(%TJ?j`z)W1D&r@|(XQ16^ZfrzOu)tkHtBt~msjHVBF$i0ob? zA1kY@Mgm4bM*Qgn{c^|xo)-lZwG=@m$^lD9GMFZ^zfX6w$(amfD)I_!lO)gTB0min z&q|T9UX`bN)o0~G(Y)lctveDB2n!G7|Hl$~zWF>lZ#|iC0jj2cTz*yyb`RjPbQAQ{ zv;jqv)^#EC;-8>gVDa<<4bT8nd~S&uB?gf(5;Lt`S=6HBJHcpy>^b87jmYD9&Xx9= zl^ELm#Nhw{ literal 0 HcmV?d00001 diff --git a/scripts/waifulib/__pycache__/xcompile.cpython-38.pyc b/scripts/waifulib/__pycache__/xcompile.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1afaee57b7c09057fd0a4d313fd38a21a2364ce5 GIT binary patch literal 12005 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 literal 0 HcmV?d00001 diff --git a/scripts/waifulib/__pycache__/xcompile.cpython-39.pyc b/scripts/waifulib/__pycache__/xcompile.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cfb561d02cf6e8d8a66f02656fe9ea68d0579122 GIT binary patch literal 12876 zcmcIrTWlOzTCQ7P-L^Zv#daL0lF6+zZab67WHPIGh~rCQHf~3;Gm|Npt!?+Iw%hKm z?wqQ2oT5D}WLQ9G*@2Y+!Gi4J8tz&N1W&AlgtRXRi5FDbHzdSJJOSdt61#l=sp@XG zFk^~YcS&fAjo&r~@47enDT9_O|!NnV;sOfE|m z*^p)FeaRk{CHje4C8+&CvX!e;qmtp>NOU57@V1sxMu_1O6?~`npjo>|uuZ#kU5o4q>YK+Q~b;=rHgBUr6+^EQ% zW~bN~`i`^HY#i@1mQH=F@#iY~>(t9SBl3~Gv+NAh*;#guy|y2*B75i9d3Ir6LGCqn zabISa*yWF<=Q90_^DMF=Wip=;ZZon!xNf;-v7BFb%(Z7`p<1bx$`;QkzIMO5?)b6Q zyt8%Jve7eMK(k#ets~#H%$db4HdiXRIU_xjn|rvtIA`YOzG&WCUYa+$4%KAT&xo?0 z^;0rHNf#w2DCtGQ%LEC_Oee9Z`pKSDp^cx82 zH^@fWDU29mW9&5EC)qeVgZD5|0q+r_1m2@W2fRx+oMDq}3N<>r%HF{HER#W{>wav;X1rQrIS#Iu777uh%|AjT;cga>^OtCE$PLMq z8X8i$p(0fp3R2b8=A;kDcO!0OFWQLgQ?FP<+Ke%2OXXv-^yI;lv4*@CXEIav60Wu{ z4@vuwD>t&4+)Id_>b|lY73Ho*bYJHG<)#|Z=knLz+l@71d)@mIzHnNz59VNTv?me5~zPwow~6VxYwqap2$ z?9-ROiQFjV__xFir^MKAxu;sA`r4zI1SWs$H>cSKrR_Qhu#$ z>9uOfc1!lU?pAeo!_s-R>gv^^9&DgYsC+3O|SnsN%51hr4|rDDBYTASJlb zE;%k$yn7on{|6q)J0GrV(lkqU$u-T%TjgpYUv}O_rrF&~J=j{Gd}wW#oKn^Pj8^E& zlR`+m;YaqCU43d3VssvM`GS6d`H@07Z?CT&r1QLD<=0Bt?YHyUjXY-uU59GCb2N}u zEl0P3X{TPRRk^EEzhb$XclDV&i{8zd2a9^y+P2DizV22ldA9@@%g^+uc}I6ZO%Uq> z)Ir^%98DO`~)T+gnR&^^zgiGR>snK552xI4a@ua*3STdkH08~Kv$Yk6MS z@cR#GTysA6-g`3-SA3=F_)$y?w({dP+cJq}ex#Up^JQP#1Yh}DE$?plQELa7b$ktM zWBUni?~oaG)Qf8GuiJ@bI@*9zA%l{BU)Ct`mg2v$N*X%wv9vC^K|; zz`dD=a|;is(NC2evxU~q@j#Nfw3y?h_B`w5@I&pN#MZV50z2xXuuDp4Tq~yvKedgg3#`v*NUNedy zub*@vK(6z&(9{IH=MdnS?IpNhjo|su4K?Ka%9TLUv4)+SH)sti z-axcq&sV{WE*r0a8BL!9<{uiaYWWQ`*oR1$3acC1dObDO%3fM&B4+Gl^IfoBjd)0>$B$%{!)xOgDlI)#0#Qi~QfdsYr zNBNcj{3r^rYG5Alp@zcKWScVR8v810WzJ(6;rRY(6k^yZ4T5Z;vgJO_cIW_vC``{R9_N>lFj(T7004G6SYT+0TLb(6?^cVnc1S3 zhs+j9CBp#BMMi=!5nv`LDHsk>VzkjFqrE&u2bsxXOyCh@{xUL5hOIAzc^A&15Z_Uz z?5g(VkkFTzx~thy5DISwXL1v6G>d*sZfHc7T@`L%bT1~-I9d}Rm;9sMjao;ScfoRj8^j;%&rh+*+%b%5Emf-$w<%O9|mNu+{EU?lnp-Bf*Bh z=8&n%FHzM6B$-HHqfoQa)B2*or}#uL&k>Xl5x&+7g*L`bn)c5yi9=l_NOK$(T2wqy zWkB)952O0!p&jTZ(I%7&bl*lMKsDEebiu!7Di8@TRiIMH1CfAfC#79EkQR)Hq9)Ri z_n}cU(VPc9yuh-AInu-ja@JSZN_Hj|piCf&EZa7=0wfuzgZ3ap&WMHj>!@xM9N5Mk zq2h1Q-=VkysgYrrr=7gk*|}r!v~RW+Ka7G4C9+3crtT9WG%PDvl#=6QLxO}Y3b$eA zVnxSUL??)NSbE(pl^sF1zr!qnK_`17hw0SO>m?{v3=<@}hD=DJQ6do$qe&j2`dX0l z38vT}A8lh9E$8)%{aMdu1J7-mXcTxmDtP2YBw*z>aX!SC0)id4GNn-X4lSjrzWZb^ z*<4Pc@c#k-pn(7N*E?6>#lmV&U4Q*`{$&FCIC#~<&d%Q-0l2FL@XpRl5L3)SV4QSY zh;gy!x$>s6hhUZ94rQNQ7&Yf5No!<91cLWt1UN;gh9m6qB{UrepBVFxXlx-=lfCXH zd}7*{AZ%$#f-vA*kpeboKq0yaZ3Q|mk~3m~59t77J3D~1>_@RBxK_oFmFz;f&a4jZ z{(vBD>8|5oh7Tjgo0#jL2z1gVlH&EXz-~2nz)rkOY$LF{fDGV;G6{H@50Jj6ZC99N zIyAk^Xhmv67Ai<_wM~QtMM^=zIP|z8^thHosDW3Eh%iOGvF2XqOyvV(4SVAh*&Vb; zCW8GVQ=*uLQA`A2U{y`3ybq} z=E?^v50{r$MX;jHot^9D>ll6<&G`lz{sm9Sr%5Q>wnrU)z91L@o#>C`sI{yGEOK3< zeOxR}=I0s+iU+hFlGf$7(Pm#n8Cs0rLmTO0XyGA=skE~bPoSSl{m=?z>_tQ?9exD0 zGXDs*(S6Cm8|GRZLD-MbHxbMpgwl6Oe&ZtOIe}gYmfBMI_ZkWgPr5%9P=s@Q8*jkk zd>b?L1TzFR{JUZe$t@WSgiD(Cmpqu>P{qDrQh>$8WG4KZ|0cKsLqUth<+SX*)l^l% zjP1bf51fae#zdLOK`dKwH|mu&FPW_rYxQZ{s@ed$Qb4|d2&@G+@tuRS*|~c&@6DU@ z3k!?0i}Sfv^HFZ*{^H#nWN~J8c7A2$pf5Z3-u&$9^20@A-dtJC%`UHaquI(f0!md5 zoM&kjS(-lkq@HIP4fF^Oua;(3@0qz}b7gs9b>YGE8(tcqP|Pg|u*g=B^0Al8y;>PqGNP zMTs!Bb;=2qeU@@>P_jq~dCzd7$#Udtl$0s4Dd{w)MZ>?L-l4v*o#CDgz;ad)=S+Ps z8W~cCHZ8vAul-AAuB*ilb=6cmqBv z@-W&$NkC~+aaE|1TWD*kJ0T^qh)mG9_s~Wvt79CgKBpMYTtg2n7}b!W#v(#h;E)7T z28+Ben}v~=ZP~(57`EH zL{vi&)NN)J5p`wq`inclnBZaDMK^gPr%>Z64HE> zP<8Y=kL@B1Uckwr0JJ6Lcnf_ zyTI)5Kox8_*c1q_a3+O9ZjLj8agKquSZf@%Dej>LXSP9aI-6t3CQU$xE_g=SGU&i5 zyyu+&ZgFa{HcbYB%L*`GNwFX})E2+Dvw2>n%KiZNKyJ3FT5ftnErQT_L$*?KAaaEb zDE)FpgwQz0SeSJ}dW1dNmL3wECK+O7oD|_m{U{N((dRl5VHg>5uYh=@kO3hZBo|4! zz5j=^WR!)4jJ%LJN5>5mOE678X_}QPtCuOCGEJzla?oRp`6gBfl)7 z))*eavA2;SPNl;K@T`pZ7Th`95rA|fyb+-jU$i1tMaB?X!Fgof;Ff@B6|u|iT#Gz< zwMJVuZTZdcC7qd8x#g#t`gr-l>WarLTb$$4&dcZ|hK~J08+w8Y;Ic2k4GXKLZ_x(u z?!>K@c0nFze(z4`)=nPBHrCw5;#Yc?uSSsAnAqV$^ZLdna5*;O~k9Xq(nRuL9?(gxMxIiV<;u)j>B_J z!?(>i3}tmMAwmpEmb@jQ1OpeafX_q;=BX&9P?9#gHEFX4eR}s{4l9z`6V|1vj&<+D zv_@?@tUZC+zOX0VOrX*Is2d3D`st3tX16(rx*=f(kC72B>Q358*4xZ8ntzz~RM9qq zHII@R-B34A;Ta>xabFSgGRped0I(on+?V%GQy(@6f2!F&6t)AhW7|)L?SS%VJEJ&s zw>fT?@s>8ve4_C4Y~<&qpOuQTxPcRAV|2en^wLEwZcTk0XXC9}x*3I=I@DwHY^(Mh z(_uvq?NV^_wT6b9Q@A_zHC2{AQJ%n6rf-Qk&$#E=Yizg#-oWjd3!4`)Y5@0OkZVN2 z5s^mp7LB>nK&yFCXo&N<19^gXgX6q&i}rTDTw-n6)@ym5hqzlD*E`B}>nt|*JLnn& zoqvRKv}f@#N){*qvrFEY=8Xo@3=k}5QeO#fC0Gna?kN*GA3@L0$XfE1*;!wmef-#n ztgJpLpw^x6_uZZbe#;ZsI;}i3x(4?7XA*B7xLjqu!tA8x0;ja-~ykVc3-3LTeiO$T2VfCv~m0oiT=qIuCLF7^f2Ab|3< z+FIVRj0p0ziV-hY*G-DY@}I(|Ns|LUUxoear;wn4cow!2qwBCQd`akP{u8wR2_zVW z+eH_tc!?5H?>tKhu@TQxLhEar8oo-GTB5V$<*W!d#E*mJMbS@?FBY_r_2I|v&jlqi zLyV~KAD4uy<45i<-Z7W>5_O9{csReX_}Et~&U)Ks@?+dW?5kiI@ws`NMJ=yf6KgfP z;aT2)ggSUxcOM%m%=Cc#M^Wl&fgsAbJxMn*Oc<*az2Oo1UhmS(?89XoZkaUk@=7M= zYs8g)R450>=o0Ef9PT**CcaLCf0G8wTLJw94~Y#j(cHEIna9 zkupX^H&p)=q@Xgc4~p#qaVJsMg7PL#lK2K{Vw-W{9#CG!wuS41Wawjaqw9xMlWf)C zimq_N4ic-uovG!OgJhVUeemd@JIvz*pjdIm?NZ?z&%c zA5a*x_+6sv&SGw1Y4s4Z3U(w1%sA2HHWTq*X9E)(>5$D@H7{iTTlA4m@$ygAaEGRK z*Oq#RH*2AczCxr6teZ64gEUB#0{TIK7nteQ1h|gY&r1M-NG-=dB^ZC3lHWlB|E7f* z{<~EBdzAb>C4WH4k=2YGSxtK_zd&n=V~9j6!CLqqA`fdY)x3s8Yxk4w(o5^3y+AM+ zDK-}?d=9(J1(VU6;OF;(DTmsV97dLp}C9DN5hv0~VyZQJz<%RqK=i4upBHz~pYScLoRS1Gqo38|QXGyjNke~iSB z;r=LLmH!D<(K)%02TttA|624YT6wyu2b30J*_sv0-Ka9Zd(8qdt*|K8e+Y#wW5bW% z3L+Wr_FyvSHj+Mh80sRp{y=B(?XUoFs`mV(^pn!1cmkn;u6QhshzWK#Ev}(IMN!cE Fe*j;y49oxk literal 0 HcmV?d00001 diff --git a/scripts/waifulib/__pycache__/xshlib.cpython-38.pyc b/scripts/waifulib/__pycache__/xshlib.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2966c6098e649c58e0dd85bcf2652637254ec47f GIT binary patch literal 5860 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 literal 0 HcmV?d00001 diff --git a/scripts/waifulib/__pycache__/xshlib.cpython-39.pyc b/scripts/waifulib/__pycache__/xshlib.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f9733c6d75f1c54c85fab096e253ea21b0aaf6ba GIT binary patch literal 5848 zcmd^DOLyDG6~>DMNzr;)b{zLKL0l^dT}yJ4Hc4a0HBH-!Vuem6rE%cnq7Vk8K#>GJ z1KKi0c4M7mXOZ^wA4uKh5A?@i+f~=yW!3KvK#H>DHht_$9t>vg%wT5j_syMq$31nb zpx}4skN1D~=4nOwD;36n1`0Ruh`%6V3R9a(OSRROW@|0o)?0>cs3g~#nO4@$woKb> zQi8GhaqQQ^e+mE4G*Yc5G0lq{ms$<6#)Zsu%0t&W>&DxMIswsc-tDd=^gy zk2s5@uQZ?%rZJr<%=lKS0t05Mz3GJo5xG&|Ei{AncF?ZJ84-otk0;kR${Q;cXLY4| zccr>anY zV5xsr*OWgf>4LQC_v&R#_zb$F6LveD=2IsDJ)Zcyyi#>;u2jowUjzA0Gax|q%_e(! z!kNu(&}2WxcLeP<1(W4(;O$Xi{6`qwz#}XqzGACPv4MfDGtGvs?M%AcvMdXYoAGO@ zvK{U>L(h%e&8F`F{N5Grx5CH1Y0kE zYgOC4x7nzGC{kGjweXwApfzaK`6nA4I+KD zR7f^8*~K_dR$3Y-SZVZVvp8S(+dg+;%VUFh9#2V26>^99UekqzpAddTROxgh5lE@D7i=p?Iuo^kiSF8&nc1IK1?Lb-$eyI<1E)W zNsh6cw)hQdN;5ldx#)a|r@YkGrxvt#R@y}?v8R@2rPb~dz6J^d7pGDI&(j8pNJ4co zl}G%BNs|0NW}47q?Thlpr_TDu$1+17y0ZpSe06W_?y%;F;7AMVH>#zY@>)fHjNVjU z-&kF_>3m*ZyL)?WR33g;R#IV9L*J9qL&;%Zd}-J-%~C7+K6>FLOSckzRKLrdh_VFu z5Y|Hr_6y*2jQ}H?Ocsojz+xNz>y?_7J;NHLgvZ2D-D~a^~ z5MEB6*@>I|=OjICifQrS8lY1`-^d|1Tz z827C5C+(4eWvM-QSCP-#SP;2jk#wKt#n8KY@bId{?mI2k7O%vrKZayt->=c&UfAkf zuVSRX<57Co$KB1vYvkcI#r4G}Jcy*12WKGg1^hh`9o8Ox=-4_)hjJa{BFlA5C+p~| zq?^%N&hJ_m=Ea4}*4yML90{#hP_eg#nN$&5Yr z!+GnpL+0E01Tic=HWR%g;**+(ADNLZQ!+iN+qshz_8Dd=k2OU%aBkw{y!6Ah?dj+} z{86w-kJRicGJUY{0IWMu209pt$VoC%Pg#mU1G0prLmBwFuY;vPNN=*5Jj@BBcOn8S14(WYN3`b);Uw1w_8F8r zVI97;(?#foo&MP6M-49-45HC#JmLis^7vmU@cs7~jPAqp16BI$DkPJr1F`$^!r)O- z8jB3}GuRS{3&>29m%ne)_UP;TxdX)8cxRb`I^%_mFJP{XXS%9H`TYV~PaLRyqprS& z@tp~lfx*r8K9ZUko+CBH2)GZBCrQwzYZ4fi_O`R-H#g$r)H`*gU$s=^pQ2%$OGglKHVLiyPpLmSCUY5v2kJIok@e_622L^t^Snhvkfj>4X2pa738)WHCoicKqabfU zCJ_%z;~s==LnhVUg_G$r{s}N7_1*YKG!l7%oIHqQ28E2AWP&tuk_p=y|MUgn3FLt< z%-sPz166rJ?6?SafIbZvwMJ$?OU!7PjU3ZnSL*7Ail#WmqYF%@(4hAL;uU#WF&^(C zlA`-A!mi~8ZEG`VBm7Nql&5v?{LnZuy7r*x7*P*SV6nKxDI}?u@)AD@6knsY{hE?5 zDWMCQc$&bA@EK?Gsk}4bKO?c326sTgqOuy{7SEt*B&ghma150k#aqnph;7J|a|MXZ zAu{W|@d^ym4%L#*X^+Kb%CI=Q=_9`NO9p>PgGdrcL-yO@m`AE4Kjd`CitzJDmhlL( zF0dQWxaqe1j eVRL;FeI&cjL6e4-({pCdm^EkTW{ug*dF>zdIlI^Z literal 0 HcmV?d00001 diff --git a/scripts/waifulib/compiler_optimizations.py b/scripts/waifulib/compiler_optimizations.py new file mode 100644 index 00000000..b426f016 --- /dev/null +++ b/scripts/waifulib/compiler_optimizations.py @@ -0,0 +1,164 @@ +# encoding: utf-8 +# compiler_optimizations.py -- main entry point for configuring C/C++ compilers +# Copyright (C) 2021 a1batross +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +try: from fwgslib import get_flags_by_type, get_flags_by_compiler +except: from waflib.extras.fwgslib import get_flags_by_type, get_flags_by_compiler +from waflib.Configure import conf +from waflib import Logs + +''' +Flags can be overriden and new types can be added +by importing this as normal Python module + +Example: +#!/usr/bin/env python +from waflib.extras import compiler_optimizations + +compiler_optimizations.VALID_BUILD_TYPES += 'gottagofast' +compiler_optimizations.CFLAGS['gottagofast'] = { + 'gcc': ['-Ogentoo'] +} +''' + +VALID_BUILD_TYPES = ['fastnative', 'fast', 'release', 'debug', 'nooptimize', 'sanitize', 'none'] + +LINKFLAGS = { + 'common': { + 'msvc': ['/DEBUG'], # always create PDB, doesn't affect result binaries + 'gcc': ['-Wl,--no-undefined'], + 'owcc': ['-Wl,option stack=512k'] + }, + 'sanitize': { + 'clang': ['-fsanitize=undefined', '-fsanitize=address'], + 'gcc': ['-fsanitize=undefined', '-fsanitize=address'], + } +} + +CFLAGS = { + 'common': { + # disable thread-safe local static initialization for C++11 code, as it cause crashes on Windows XP + 'msvc': ['/D_USING_V110_SDK71_', '/Zi', '/FS', '/Zc:threadSafeInit-', '/MT'], + 'clang': ['-g', '-gdwarf-2', '-fvisibility=hidden'], + 'gcc': ['-fvisibility=hidden'], + 'owcc': ['-fno-short-enum', '-ffloat-store', '-g3'] + }, + 'fast': { + 'msvc': ['/O2', '/Oy'], + 'gcc': { + '3': ['-O3', '-fomit-frame-pointer'], + 'default': ['-Ofast', '-funsafe-math-optimizations', '-funsafe-loop-optimizations', '-fomit-frame-pointer'] + }, + 'clang': ['-Ofast'], + 'default': ['-O3'] + }, + 'fastnative': { + 'msvc': ['/O2', '/Oy'], + 'gcc': ['-Ofast', '-march=native', '-funsafe-math-optimizations', '-funsafe-loop-optimizations', '-fomit-frame-pointer'], + 'clang': ['-Ofast', '-march=native'], + 'default': ['-O3'] + }, + 'release': { + 'msvc': ['/O2'], + 'owcc': ['-O3', '-foptimize-sibling-calls', '-fomit-leaf-frame-pointer', '-fomit-frame-pointer', '-fschedule-insns', '-funsafe-math-optimizations', '-funroll-loops', '-frerun-optimizer', '-finline-functions', '-finline-limit=512', '-fguess-branch-probability', '-fno-strict-aliasing', '-floop-optimize'], + 'default': ['-O0'] + }, + 'debug': { + 'msvc': ['/Od'], + 'owcc': ['-O0', '-fno-omit-frame-pointer', '-funwind-tables', '-fno-omit-leaf-frame-pointer'], + 'default': ['-O0'] + }, + 'sanitize': { + 'msvc': ['/Od', '/RTC1'], + 'gcc': ['-Og', '-fsanitize=undefined', '-fsanitize=address'], + 'clang': ['-O0', '-fsanitize=undefined', '-fsanitize=address'], + 'default': ['-O0'] + }, + 'nooptimize': { + 'msvc': ['/Od'], + 'default': ['-O0'] + } +} + +LTO_CFLAGS = { + 'msvc': ['/GL'], + 'gcc': ['-flto'], + 'clang': ['-flto'] +} + +LTO_LINKFLAGS = { + 'msvc': ['/LTCG'], + 'gcc': ['-flto'], + 'clang': ['-flto'] +} + +POLLY_CFLAGS = { + 'gcc': ['-fgraphite-identity'], + 'clang': ['-mllvm', '-polly'] + # msvc sosat :( +} + +def options(opt): + grp = opt.add_option_group('Compiler optimization options') + + grp.add_option('-T', '--build-type', action='store', dest='BUILD_TYPE', default=None, + help = 'build type: debug, release or none(custom flags)') + + grp.add_option('--enable-lto', action = 'store_true', dest = 'LTO', default = False, + help = 'enable Link Time Optimization if possible [default: %default]') + + grp.add_option('--enable-poly-opt', action = 'store_true', dest = 'POLLY', default = False, + help = 'enable polyhedral optimization if possible [default: %default]') + +def configure(conf): + conf.start_msg('Build type') + if conf.options.BUILD_TYPE == None: + conf.end_msg('not set', color='RED') + conf.fatal('Set a build type, for example "-T release"') + elif not conf.options.BUILD_TYPE in VALID_BUILD_TYPES: + conf.end_msg(conf.options.BUILD_TYPE, color='RED') + conf.fatal('Invalid build type. Valid are: %s' % ', '.join(VALID_BUILD_TYPES)) + conf.end_msg(conf.options.BUILD_TYPE) + + conf.msg('LTO build', 'yes' if conf.options.LTO else 'no') + conf.msg('PolyOpt build', 'yes' if conf.options.POLLY else 'no') + + # -march=native should not be used + if conf.options.BUILD_TYPE.startswith('fast'): + Logs.warn('WARNING: \'%s\' build type should not be used in release builds', conf.options.BUILD_TYPE) + + try: + conf.env.CC_VERSION[0] + except IndexError: + conf.env.CC_VERSION = (0,) + +@conf +def get_optimization_flags(conf): + '''Returns a list of compile flags, + depending on build type and options set by user + + NOTE: it doesn't filter out unsupported flags + + :returns: tuple of cflags and linkflags + ''' + linkflags = conf.get_flags_by_type(LINKFLAGS, conf.options.BUILD_TYPE, conf.env.COMPILER_CC, conf.env.CC_VERSION[0]) + + cflags = conf.get_flags_by_type(CFLAGS, conf.options.BUILD_TYPE, conf.env.COMPILER_CC, conf.env.CC_VERSION[0]) + + if conf.options.LTO: + linkflags+= conf.get_flags_by_compiler(LTO_LINKFLAGS, conf.env.COMPILER_CC) + cflags += conf.get_flags_by_compiler(LTO_CFLAGS, conf.env.COMPILER_CC) + + if conf.options.POLLY: + cflags += conf.get_flags_by_compiler(POLLY_CFLAGS, conf.env.COMPILER_CC) + + return cflags, linkflags diff --git a/scripts/waifulib/owcc.py b/scripts/waifulib/owcc.py new file mode 100755 index 00000000..efee4131 --- /dev/null +++ b/scripts/waifulib/owcc.py @@ -0,0 +1,124 @@ +#! /usr/bin/env python +# encoding: utf-8 + +""" +Compiler definition for OpenWatcom's owcc +""" + +from waflib import Errors, Utils +from waflib.Tools import ccroot, ar +from waflib.Configure import conf + +@conf +def find_owcc(conf): + v = conf.env + cc = None + if v.CC: + cc = v.CC + else: + cc = conf.find_program('cc', var='CC') + if not cc: + conf.fatal('owcc was not found') + + try: + out = conf.cmd_and_log(cc + ['-v']) + except Errors.WafError: + conf.fatal('%r -v could not be executed' % cc) + if not 'Open Watcom' in out: + conf.fatal('failed to detect owcc') + + v.CC = cc + v.CC_NAME = 'owcc' + v.CXX = v.CC + v.CXX_NAME = v.cc_NAME + if not v.AR: + conf.find_program('wlib', var='AR') + conf.add_os_flags('ARFLAGS') + if not v.ARFLAGS: + v.ARFLAGS = ['-fo'] + +@conf +def owcc_common_flags(conf): + v = conf.env + + v.CC_SRC_F = '' + v.CXX_SRC_F = '' + v.CC_TGT_F = ['-c', '-o'] + v.CXX_TGT_F = ['-c', '-o'] + v.CPPPATH_ST = '-I%s' + v.DEFINES_ST = '-D%s' + + if not v.LINK_CC: + v.LINK_CC = v.CC + if not v.LINK_CXX: + v.LINK_CXX = v.CXX + + v.CCLNK_SRC_F = '' + v.CCLNK_TGT_F = ['-o'] + v.CXXLNK_SRC_F = '' + v.CXXLNK_TGT_F = ['-o'] + + v.LIB_ST = '-l%s' # template for adding libs + v.LIBPATH_ST = '-L%s' # template for adding libpaths + v.STLIB_ST = '-l%s' + v.STLIBPATH_ST = '-L%s' + + v.cprogram_PATTERN = '%s.exe' + v.cxxprogram_PATTERN = '%s.exe' + v.cshlib_PATTERN = 'lib%s.so' + v.cxxshlib_PATTERN = 'lib%s.so' + v.cstlib_PATTERN = '%s.a' + v.cxxstlib_PATTERN = '%s.a' + +def find_target(flags): + if '-b' in flags: + return flags[flags.index('-b')+1] + +@conf +def owcc_detect_platform(conf): + v = conf.env + target = find_target(v.LINKFLAGS) + if not target: + target = find_target(v.CC) + if not target: + target = find_target(v.CFLAGS) + if not target: + target = Utils.unversioned_sys_platform() + if target in ['dos4g', 'dos4gnz', 'dos32a', 'stub32a', 'stub32ac']: + v.DEST_BINFMT = 'le' + v.DEST_OS = 'dos' + elif target in ['dos32x', 'stub32x', 'stub32xc']: + v.DEST_BINFMT = 'lx' + v.DEST_OS = 'dos' + elif target.startswith('win') or target.startswith('nt'): + v.DEST_BINFMT = 'pe' + v.DEST_OS = 'win32' + elif target == 'qnx386': + v.DEST_OS = 'qnx' + v.DEST_BINFMT = 'qnx' + elif target in ['linux', '386']: + v.DEST_OS = 'linux' + v.DEST_BINFMT = 'elf' + else: + v.DEST_OS = target + v.DEST_BINFMT = None + + v.DEST_CPU = 'i386' + + for f in v.LINKFLAGS + v.CC + v.CFLAGS: + if f.startswith('-march'): + v.DEST_CPU=f.split('=')[1] + break + + +def configure(conf): + conf.find_owcc() + conf.owcc_common_flags() + conf.cc_load_tools() + conf.cc_add_flags() + conf.env.append_unique('CFLAGS','-Wc,-xx') + conf.cxx_load_tools() + conf.cxx_add_flags() + conf.env.append_unique('CXXFLAGS','-Wc,-xx') + conf.link_add_flags() + conf.owcc_detect_platform() diff --git a/scripts/waifulib/xcompile.py b/scripts/waifulib/xcompile.py new file mode 100644 index 00000000..86c343fd --- /dev/null +++ b/scripts/waifulib/xcompile.py @@ -0,0 +1,433 @@ +# encoding: utf-8 +# xcompile.py -- crosscompiling utils +# Copyright (C) 2018 a1batross +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +try: from fwgslib import get_flags_by_compiler +except: from waflib.extras.fwgslib import get_flags_by_compiler +from waflib import Logs, TaskGen +from waflib.Tools import c_config +from collections import OrderedDict +import os +import sys + +ANDROID_NDK_ENVVARS = ['ANDROID_NDK_HOME', 'ANDROID_NDK'] +ANDROID_NDK_SUPPORTED = [10, 19, 20] +ANDROID_NDK_HARDFP_MAX = 11 # latest version that supports hardfp +ANDROID_NDK_GCC_MAX = 17 # latest NDK that ships with GCC +ANDROID_NDK_UNIFIED_SYSROOT_MIN = 15 +ANDROID_NDK_SYSROOT_FLAG_MAX = 19 # latest NDK that need --sysroot flag +ANDROID_NDK_API_MIN = { 10: 3, 19: 16, 20: 16 } # minimal API level ndk revision supports +ANDROID_64BIT_API_MIN = 21 # minimal API level that supports 64-bit targets + +# This class does support ONLY r10e and r19c/r20 NDK +class Android: + ctx = None # waf context + arch = None + toolchain = None + api = None + ndk_home = None + ndk_rev = 0 + is_hardfloat = False + clang = False + + def __init__(self, ctx, arch, toolchain, api): + self.ctx = ctx + self.api = api + self.toolchain = toolchain + self.arch = arch + + for i in ANDROID_NDK_ENVVARS: + self.ndk_home = os.getenv(i) + if self.ndk_home != None: + break + else: + ctx.fatal('Set %s environment variable pointing to the root of Android NDK!' % + ' or '.join(ANDROID_NDK_ENVVARS)) + + # TODO: this were added at some point of NDK development + # but I don't know at which version + # r10e don't have it + source_prop = os.path.join(self.ndk_home, 'source.properties') + if os.path.exists(source_prop): + with open(source_prop) as ndk_props_file: + for line in ndk_props_file.readlines(): + tokens = line.split('=') + trimed_tokens = [token.strip() for token in tokens] + + if 'Pkg.Revision' in trimed_tokens: + self.ndk_rev = int(trimed_tokens[1].split('.')[0]) + + if self.ndk_rev not in ANDROID_NDK_SUPPORTED: + ctx.fatal('Unknown NDK revision: %d' % (self.ndk_rev)) + else: + self.ndk_rev = ANDROID_NDK_SUPPORTED[0] + + if 'clang' in self.toolchain or self.ndk_rev > ANDROID_NDK_GCC_MAX: + self.clang = True + + if self.arch == 'armeabi-v7a-hard': + if self.ndk_rev <= ANDROID_NDK_HARDFP_MAX: + self.arch = 'armeabi-v7a' # Only armeabi-v7a have hard float ABI + self.is_hardfloat = True + else: + ctx.fatal('NDK does not support hardfloat ABI') + + if self.api < ANDROID_NDK_API_MIN[self.ndk_rev]: + self.api = ANDROID_NDK_API_MIN[self.ndk_rev] + Logs.warn('API level automatically was set to %d due to NDK support' % self.api) + + if self.is_arm64() or self.is_amd64() and self.api < ANDROID_64BIT_API_MIN: + self.api = ANDROID_64BIT_API_MIN + Logs.warn('API level for 64-bit target automatically was set to %d' % self.api) + + def is_host(self): + ''' + Checks if we using host compiler(implies clang) + ''' + return self.toolchain == 'host' + + def is_arm(self): + ''' + Checks if selected architecture is **32-bit** ARM + ''' + return self.arch.startswith('armeabi') + + def is_x86(self): + ''' + Checks if selected architecture is **32-bit** or **64-bit** x86 + ''' + return self.arch == 'x86' + + def is_amd64(self): + ''' + Checks if selected architecture is **64-bit** x86 + ''' + return self.arch == 'x86_64' + + def is_arm64(self): + ''' + Checks if selected architecture is AArch64 + ''' + return self.arch == 'aarch64' + + def is_clang(self): + ''' + Checks if selected toolchain is Clang (TODO) + ''' + return self.clang + + def is_hardfp(self): + return self.is_hardfloat + + def ndk_triplet(self, llvm_toolchain = False, toolchain_folder = False): + if self.is_x86(): + if toolchain_folder: + return 'x86' + else: + return 'i686-linux-android' + elif self.is_arm(): + if llvm_toolchain: + return 'armv7a-linux-androideabi' + else: + return 'arm-linux-androideabi' + elif self.is_amd64() and toolchain_folder: + return 'x86_64' + else: + return self.arch + '-linux-android' + + def apk_arch(self): + if self.is_arm64(): + return 'arm64-v8a' + return self.arch + + def gen_host_toolchain(self): + # With host toolchain we don't care about OS + # so just download NDK for Linux x86_64 + if 'HOST_TOOLCHAIN' in self.ctx.environ: + return self.ctx.environ['HOST_TOOLCHAIN'] + if self.is_host(): + return 'linux-x86_64' + + if sys.platform.startswith('win32') or sys.platform.startswith('cygwin'): + osname = 'windows' + elif sys.platform.startswith('darwin'): + osname = 'darwin' + elif sys.platform.startswith('linux'): + osname = 'linux' + else: + self.ctx.fatal('Unsupported by NDK host platform') + + if sys.maxsize > 2**32: + arch = 'x86_64' + else: arch = 'x86' + + return '%s-%s' % (osname, arch) + + def gen_gcc_toolchain_path(self): + path = 'toolchains' + toolchain_host = self.gen_host_toolchain() + + if self.is_clang(): + toolchain_folder = 'llvm' + else: + if self.is_host(): + toolchain = '4.9' + else: + toolchain = self.toolchain + + toolchain_folder = '%s-%s' % (self.ndk_triplet(toolchain_folder = True), toolchain) + + return os.path.abspath(os.path.join(self.ndk_home, path, toolchain_folder, 'prebuilt', toolchain_host)) + + def gen_toolchain_path(self): + if self.is_clang(): + triplet = '%s%d-' % (self.ndk_triplet(llvm_toolchain = True), self.api) + else: + triplet = self.ndk_triplet() + '-' + return os.path.join(self.gen_gcc_toolchain_path(), 'bin', triplet) + + def gen_binutils_path(self): + return os.path.join(self.gen_gcc_toolchain_path(), self.ndk_triplet(), 'bin') + + def cc(self): + if self.is_host(): + return 'clang --target=%s%d' % (self.ndk_triplet(), self.api) + return self.gen_toolchain_path() + ('clang' if self.is_clang() else 'gcc') + + def cxx(self): + if self.is_host(): + return 'clang++ --target=%s%d' % (self.ndk_triplet(), self.api) + return self.gen_toolchain_path() + ('clang++' if self.is_clang() else 'g++') + + def strip(self): + if self.is_host(): + return 'llvm-strip' + return os.path.join(self.gen_binutils_path(), 'strip') + + def system_stl(self): + # TODO: proper STL support + return os.path.abspath(os.path.join(self.ndk_home, 'sources', 'cxx-stl', 'system', 'include')) + + def libsysroot(self): + arch = self.arch + if self.is_arm(): + arch = 'arm' + elif self.is_arm64(): + arch = 'arm64' + path = 'platforms/android-%s/arch-%s' % (self.api, arch) + + return os.path.abspath(os.path.join(self.ndk_home, path)) + + def sysroot(self): + if self.ndk_rev >= ANDROID_NDK_UNIFIED_SYSROOT_MIN: + return os.path.abspath(os.path.join(self.ndk_home, 'sysroot')) + else: + return self.libsysroot() + + def cflags(self, cxx = False): + cflags = [] + + if self.ndk_rev <= ANDROID_NDK_SYSROOT_FLAG_MAX: + cflags += ['--sysroot=%s' % (self.sysroot())] + else: + if self.is_host(): + cflags += [ + '--sysroot=%s/sysroot' % (self.gen_gcc_toolchain_path()), + '-isystem', '%s/usr/include/' % (self.sysroot()) + ] + + cflags += ['-I%s' % (self.system_stl()), '-DANDROID', '-D__ANDROID__'] + + if cxx and not self.is_clang() and self.toolchain not in ['4.8','4.9']: + cflags += ['-fno-sized-deallocation'] + + def fixup_host_clang_with_old_ndk(): + cflags = [] + # Clang builtin redefine w/ different calling convention bug + # NOTE: I did not added complex.h functions here, despite + # that NDK devs forgot to put __NDK_FPABI_MATH__ for complex + # math functions + # I personally don't need complex numbers support, but if you want it + # just run sed to patch header + for f in ['strtod', 'strtof', 'strtold']: + cflags += ['-fno-builtin-%s' % f] + return cflags + + + if self.is_arm(): + if self.arch == 'armeabi-v7a': + # ARMv7 support + cflags += ['-mthumb', '-mfpu=neon', '-mcpu=cortex-a9', '-DHAVE_EFFICIENT_UNALIGNED_ACCESS', '-DVECTORIZE_SINCOS'] + + if not self.is_clang() and not self.is_host(): + cflags += [ '-mvectorize-with-neon-quad' ] + + if self.is_host() and self.ndk_rev <= ANDROID_NDK_HARDFP_MAX: + cflags += fixup_host_clang_with_old_ndk() + + if self.is_hardfp(): + cflags += ['-D_NDK_MATH_NO_SOFTFP=1', '-mfloat-abi=hard', '-DLOAD_HARDFP', '-DSOFTFP_LINK'] + else: + cflags += ['-mfloat-abi=softfp'] + else: + if self.is_host() and self.ndk_rev <= ANDROID_NDK_HARDFP_MAX: + cflags += fixup_host_clang_with_old_ndk() + + # ARMv5 support + cflags += ['-march=armv5te', '-msoft-float'] + elif self.is_x86(): + cflags += ['-mtune=atom', '-march=atom', '-mssse3', '-mfpmath=sse', '-DVECTORIZE_SINCOS', '-DHAVE_EFFICIENT_UNALIGNED_ACCESS'] + return cflags + + # they go before object list + def linkflags(self): + linkflags = [] + if self.is_host(): + linkflags += ['--gcc-toolchain=%s' % self.gen_gcc_toolchain_path()] + + if self.ndk_rev <= ANDROID_NDK_SYSROOT_FLAG_MAX: + linkflags += ['--sysroot=%s' % (self.sysroot())] + elif self.is_host(): + linkflags += ['--sysroot=%s/sysroot' % (self.gen_gcc_toolchain_path())] + + if self.is_clang() or self.is_host(): + linkflags += ['-fuse-ld=lld'] + + linkflags += ['-Wl,--hash-style=sysv', '-Wl,--no-undefined', '-no-canonical-prefixes'] + return linkflags + + def ldflags(self): + ldflags = ['-lgcc', '-no-canonical-prefixes'] + if self.is_clang() or self.is_host(): + ldflags += ['-stdlib=libstdc++'] + if self.is_arm(): + if self.arch == 'armeabi-v7a': + ldflags += ['-march=armv7-a', '-mthumb'] + + if not self.is_clang() and not self.is_host(): # lld only + ldflags += ['-Wl,--fix-cortex-a8'] + + if self.is_hardfp(): + ldflags += ['-Wl,--no-warn-mismatch', '-lm_hard'] + else: + ldflags += ['-march=armv5te'] + return ldflags + +def options(opt): + android = opt.add_option_group('Android options') + android.add_option('--android', action='store', dest='ANDROID_OPTS', default=None, + help='enable building for android, format: --android=,,, example: --android=armeabi-v7a-hard,4.9,9') + + magx = opt.add_option_group('MotoMAGX options') + magx.add_option('--enable-magx', action = 'store_true', dest = 'MAGX', default = False, + help = 'enable targetting for MotoMAGX phones [default: %default]') + +def configure(conf): + if conf.options.ANDROID_OPTS: + values = conf.options.ANDROID_OPTS.split(',') + if len(values) != 3: + conf.fatal('Invalid --android paramater value!') + + valid_archs = ['x86', 'x86_64', 'armeabi', 'armeabi-v7a', 'armeabi-v7a-hard', 'aarch64'] + + if values[0] not in valid_archs: + conf.fatal('Unknown arch: %s. Supported: %r' % (values[0], ', '.join(valid_archs))) + + conf.android = android = Android(conf, values[0], values[1], int(values[2])) + conf.environ['CC'] = android.cc() + conf.environ['CXX'] = android.cxx() + conf.environ['STRIP'] = android.strip() + conf.env.CFLAGS += android.cflags() + conf.env.CXXFLAGS += android.cflags(True) + conf.env.LINKFLAGS += android.linkflags() + conf.env.LDFLAGS += android.ldflags() + + conf.env.HAVE_M = True + if android.is_hardfp(): + conf.env.LIB_M = ['m_hard'] + else: conf.env.LIB_M = ['m'] + + conf.env.PREFIX = '/lib/%s' % android.apk_arch() + + conf.msg('Selected Android NDK', '%s, version: %d' % (android.ndk_home, android.ndk_rev)) + # no need to print C/C++ compiler, as it would be printed by compiler_c/cxx + conf.msg('... C/C++ flags', ' '.join(android.cflags()).replace(android.ndk_home, '$NDK/')) + conf.msg('... link flags', ' '.join(android.linkflags()).replace(android.ndk_home, '$NDK/')) + conf.msg('... ld flags', ' '.join(android.ldflags()).replace(android.ndk_home, '$NDK/')) + + # conf.env.ANDROID_OPTS = android + conf.env.DEST_OS2 = 'android' + elif conf.options.MAGX: + # useless to change toolchain path, as toolchain meant to be placed in this path + toolchain_path = '/opt/toolchains/motomagx/arm-eabi2/lib/' + conf.env.INCLUDES_MAGX = [toolchain_path + i for i in ['ezx-z6/include', 'qt-2.3.8/include']] + conf.env.LIBPATH_MAGX = [toolchain_path + i for i in ['ezx-z6/lib', 'qt-2.3.8/lib']] + conf.env.LINKFLAGS_MAGX = ['-Wl,-rpath-link=' + i for i in conf.env.LIBPATH_MAGX] + for lib in ['qte-mt', 'ezxappbase', 'ezxpm', 'log_util']: + conf.check_cc(lib=lib, use='MAGX', uselib_store='MAGX') + + conf.env.MAGX = conf.options.MAGX + MACRO_TO_DESTOS = OrderedDict({ '__ANDROID__' : 'android' }) + for k in c_config.MACRO_TO_DESTOS: + MACRO_TO_DESTOS[k] = c_config.MACRO_TO_DESTOS[k] # ordering is important + c_config.MACRO_TO_DESTOS = MACRO_TO_DESTOS + +def post_compiler_cxx_configure(conf): + conf.msg('Target OS', conf.env.DEST_OS) + conf.msg('Target CPU', conf.env.DEST_CPU) + conf.msg('Target binfmt', conf.env.DEST_BINFMT) + + if conf.options.ANDROID_OPTS: + if conf.android.ndk_rev == 19: + conf.env.CXXFLAGS_cxxshlib += ['-static-libstdc++'] + conf.env.LDFLAGS_cxxshlib += ['-static-libstdc++'] + return + +def post_compiler_c_configure(conf): + conf.msg('Target OS', conf.env.DEST_OS) + conf.msg('Target CPU', conf.env.DEST_CPU) + conf.msg('Target binfmt', conf.env.DEST_BINFMT) + + return + +from waflib.Tools import compiler_cxx, compiler_c + +compiler_cxx_configure = getattr(compiler_cxx, 'configure') +compiler_c_configure = getattr(compiler_c, 'configure') + +def patch_compiler_cxx_configure(conf): + compiler_cxx_configure(conf) + post_compiler_cxx_configure(conf) + +def patch_compiler_c_configure(conf): + compiler_c_configure(conf) + post_compiler_c_configure(conf) + +setattr(compiler_cxx, 'configure', patch_compiler_cxx_configure) +setattr(compiler_c, 'configure', patch_compiler_c_configure) + +@TaskGen.feature('cshlib', 'cxxshlib', 'dshlib', 'fcshlib', 'vnum') +@TaskGen.after_method('apply_link', 'propagate_uselib_vars') +@TaskGen.before_method('apply_vnum') +def apply_android_soname(self): + """ + Enforce SONAME on Android + """ + if self.env.DEST_OS != 'android': + return + + setattr(self, 'vnum', None) # remove vnum, so SONAME would not be overwritten + link = self.link_task + node = link.outputs[0] + libname = node.name + v = self.env.SONAME_ST % libname + self.env.append_value('LINKFLAGS', v.split()) diff --git a/scripts/waifulib/xshlib.py b/scripts/waifulib/xshlib.py new file mode 100644 index 00000000..60c10120 --- /dev/null +++ b/scripts/waifulib/xshlib.py @@ -0,0 +1,115 @@ +# encoding: utf-8 +# xshlib.py -- advanced linking utils +# Copyright (C) 2019 mittorn +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +from waflib import Logs, Utils, TaskGen, Task +from waflib.Tools import ccroot, c, cxx + +MAIN_BINARY = 'xash' + +def options(opt): + opt.add_option('--static-linking', action='store', dest='STATIC_LINKING', default=None) + +def configure(conf): + if conf.options.STATIC_LINKING: + conf.find_program('ld') + conf.find_program('objcopy') + conf.env.STATIC_LINKING = conf.options.STATIC_LINKING + conf.add_os_flags('LD_RELOCATABLE_FLAGS') + +def build(bld): + if bld.env.STATIC_LINKING: + apply_static(MAIN_BINARY,*bld.env.STATIC_LINKING.split(',')) + +class objcopy_relocatable_lib(Task.Task): + "remove all exports except of lib_${NAME}_exports" + no_errcheck_out = True + run_str = '${OBJCOPY} -G lib_${NAME}_exports ${SRC[0].abspath()} ${TGT[0].abspath()}' + def keyword(self): + return 'ObjCopy' + +class xshlib(ccroot.link_task): + "make relocatable library" + no_errcheck_out = True + run_str = '${LD} -r -o ${TGT[0].abspath()} ${LD_RELOCATABLE_FLAGS} ${CCLNK_SRC_F}${SRC}' + + def add_target(self, target): + "create objcopy task for target" + if not self.env.LD_RELOCATABLE_FLAGS: + self.env.LD_RELOCATABLE_FLAGS = [] + if '-m32' in self.env.LINKFLAGS: + self.env.LD_RELOCATABLE_FLAGS.append('-melf_i386') + + base = self.generator.path + target_unstripped = base.find_or_declare('%s.unstripped.o'% target) + target_stripped = base.find_or_declare('%s.o'% target) + + self.set_outputs(target_unstripped) + self.generator.objcopy_task= self.generator.create_task('objcopy_relocatable_lib', target_unstripped, target_stripped) + self.generator.objcopy_task.env['NAME'] = target + +class cprogram_static(c.cprogram): + "build static c program" + run_str = '${LINK_CC} -static ${LINKFLAGS} ${CCLNK_SRC_F}${SRC} ${CCLNK_TGT_F}${TGT[0].abspath()} ${RPATH_ST:RPATH} ${FRAMEWORKPATH_ST:FRAMEWORKPATH} ${FRAMEWORK_ST:FRAMEWORK} ${ARCH_ST:ARCH} ${STLIB_MARKER} ${STLIBPATH_ST:STLIBPATH} ${STLIB_ST:STLIB} ${STLIB_MARKER} ${LIBPATH_ST:LIBPATH} ${LIB_ST:LIB} ${LDFLAGS}' + +class cxxprogram_static(cxx.cxxprogram): + "build static cxx program" + run_str = '${LINK_CXX} -static ${LINKFLAGS} ${CXXLNK_SRC_F}${SRC} ${CXXLNK_TGT_F}${TGT[0].abspath()} ${RPATH_ST:RPATH} ${FRAMEWORKPATH_ST:FRAMEWORKPATH} ${FRAMEWORK_ST:FRAMEWORK} ${ARCH_ST:ARCH} ${STLIB_MARKER} ${STLIBPATH_ST:STLIBPATH} ${STLIB_ST:STLIB} ${STLIB_MARKER} ${LIBPATH_ST:LIBPATH} ${LIB_ST:LIB} ${LDFLAGS}' + +# usevars are same +ccroot.USELIB_VARS['cprogram_static'] = ccroot.USELIB_VARS['cxxprogram_static'] = ccroot.USELIB_VARS['cxxprogram'] + +def apply_static(main, *reloc): + "apply xshlib tasks and generate files" + + def write_libraries_list(out_node): + "generate library list" + + libraries = reloc + externs = '\n'.join(['extern table_t lib_%s_exports[];' % e for e in libraries]) + table = '\n'.join(['{ "%s", &lib_%s_exports },' % (e, e) for e in libraries]) + out_node.write('%s\nstruct {const char *name;void *func;} libs[] = {\n%s\n{0,0}\n};\n' % (externs, table )) + + + def write_export_list(name, in_node, out_node): + "generate exports list for library" + + exports = in_node.read().splitlines() + externs = '\n'.join(['extern void %s(void);' % e for e in exports]) + table = '\n'.join(['{ "%s", &%s },' % (e, e) for e in exports]) + out_node.write('%s\nstruct {const char *name;void *func;} lib_%s_exports[] = {\n%s\n{0,0}\n};\n' % (externs, name, table )) + + @TaskGen.feature('cshlib', 'cxxshlib') + @TaskGen.before('process_source', 'propogate_uselib_vars') + def apply_xshlib(self): + "apply xshlib feature and inject link_helper.c to sources" + if self.name in reloc: + for k in ('cshlib', 'cxxshlib'): + if k in self.features: + self.features.remove(k) + self.features.append('xshlib') + in_node = self.path.get_src().make_node('exports.txt') + bldnode = self.path.get_bld() + bldnode.mkdir() + out_node = bldnode.make_node('link_helper.c') + write_export_list(self.name,in_node, out_node) + self.source = Utils.to_list(self.source) + [out_node] + + @TaskGen.feature('cshlib', 'cxxshlib', 'cprogram', 'cxxprogram', 'cprogram_static', 'cxxprogram_static') + @TaskGen.before('process_source') + def add_deps(self): + "add all relocatable objects to main binary source list" + if self.name == main: + write_libraries_list(self.path.get_bld().make_node('generated_library_tables.h')) + + for t in reloc: + self.source += [self.bld.get_tgen_by_name(t).objcopy_task.outputs[0]] diff --git a/serverbrowser/wscript b/serverbrowser/wscript new file mode 100755 index 00000000..9af6519c --- /dev/null +++ b/serverbrowser/wscript @@ -0,0 +1,72 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'ServerBrowser' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('SERVERBROWSER_EXPORTS',1) + conf.define('VERSION_SAFE_STEAM_API_INTERFACES',1) + conf.define('SERVERBROWSER_EXPORTS',1) + conf.define('GAME_SRC',1) + conf.define('_USE_32BIT_TIME_T',1) + +def build(bld): + source = [ + 'BaseGamesPage.cpp', + 'BlacklistedServers.cpp', + 'CustomGames.cpp', + 'DialogAddServer.cpp', + 'DialogGameInfo.cpp', + 'DialogServerPassword.cpp', + 'FavoriteGames.cpp', + 'FriendsGames.cpp', + 'HistoryGames.cpp', + 'InternetGames.cpp', + 'LanGames.cpp', + 'ModList.cpp', + 'ServerBrowser.cpp', + 'ServerBrowserDialog.cpp', + 'ServerContextMenu.cpp', + 'ServerListCompare.cpp', + 'SpectateGames.cpp', + 'VACBannedConnRefusedDialog.cpp', + 'QuickListPanel.cpp', + '../public/vgui_controls/vgui_controls.cpp', + '../common/ServerBrowser/blacklisted_server_manager.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + + defines = [] + + libs = ['tier0','vgui_controls','mathlib','tier1','tier2','tier3','vstdlib','steam_api'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/soundemittersystem/wscript b/soundemittersystem/wscript new file mode 100755 index 00000000..82df5bf9 --- /dev/null +++ b/soundemittersystem/wscript @@ -0,0 +1,53 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'SoundEmitterSystem' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('SOUNDEMITTERSYSTEM_EXPORTS',1) + conf.define('_WINDOWS',1) + conf.define('PROTECTED_THINGS_ENABLE',1) + #conf.define('fopen','dont_use_fopen') # WINDOWS + +def build(bld): + source = [ + '../game/shared/interval.cpp', + 'soundemittersystembase.cpp', + '../public/SoundParametersInternal.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../game/shared' + ] + + defines = [] + + libs = ['tier0','tier1','vstdlib'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/studiorender/wscript b/studiorender/wscript new file mode 100755 index 00000000..bc0dd0b5 --- /dev/null +++ b/studiorender/wscript @@ -0,0 +1,60 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'StudioRender' + +def options(opt): + # stub + return + +def configure(conf): + conf.env.append_unique('DEFINES',[ + 'STUDIORENDER_EXPORTS', + 'PROTECTED_THINGS_ENABLE' + ]) + +def build(bld): + source = [ + 'studiorender.cpp', + 'studiorendercontext.cpp', + 'flexrenderdata.cpp', + 'r_studio.cpp', + 'r_studiodecal.cpp', + 'r_studiodraw.cpp', + 'r_studiodraw_computeflexedvertex.cpp', + 'r_studioflex.cpp', + 'r_studiogettriangles.cpp', + 'r_studiolight.cpp', + 'r_studiostats.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + ] + + defines = [] + + libs = ['tier0','tier1','tier2','tier3','vstdlib','mathlib','bitmap'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/thirdparty b/thirdparty index 495addba..31ae58f6 160000 --- a/thirdparty +++ b/thirdparty @@ -1 +1 @@ -Subproject commit 495addbab3e40a60e3e7c7ebf3ee405a53148b0c +Subproject commit 31ae58f64f9169db7f4e02c83dba46e5a47e0c7b diff --git a/tier0/wscript b/tier0/wscript new file mode 100755 index 00000000..bf4a18c2 --- /dev/null +++ b/tier0/wscript @@ -0,0 +1,84 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'tier0' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('TIER0_DLL_EXPORT',1) +# conf.define('NO_HOOK_MALLOC',1) + +def build(bld): + source = [ + 'assert_dialog.cpp', + #'assert_dialog.rc', [$WINDOWS] + 'commandline.cpp', + 'cpu.cpp', + 'cpumonitoring.cpp', + 'cpu_posix.cpp', #[$POSIX] + 'cpu_usage.cpp', + 'dbg.cpp', + 'dynfunction.cpp', + #'etwprof.cpp', [$WINDOWS] + 'fasttimer.cpp', + # 'InterlockedCompareExchange128.masm', [$WIN64] + 'mem.cpp', + 'mem_helpers.cpp', + 'memdbg.cpp', + 'memstd.cpp', + 'memvalidate.cpp', + 'minidump.cpp', + 'pch_tier0.cpp', + #'platform.cpp', [$WINDOWS||$X360] + 'platform_posix.cpp', # [$POSIX] + #'pmc360.cpp', [$X360] + #'pme.cpp', [$WINDOWS] + 'pme_posix.cpp', # [$POSIX] + 'PMELib.cpp', #[$WINDOWS||$POSIX] + 'progressbar.cpp', + 'security.cpp', + 'systeminformation.cpp', + 'stacktools.cpp', + 'thread.cpp', #[$WINDOWS||$POSIX] + 'threadtools.cpp', + 'tier0_strtools.cpp', + 'tslist.cpp', + #'vcrmode.cpp', #[$WINDOWS] + 'vcrmode_posix.cpp', #[$POSIX] + 'vprof.cpp', + # 'win32consoleio.cpp', [$WINDOWS] + '../tier1/pathmatch.cpp' # [$LINUXALL] + ] + + includes = [ + '.', + '../public', + '../public/tier0', + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = ['DL'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/tier1/wscript b/tier1/wscript new file mode 100755 index 00000000..4063a3bf --- /dev/null +++ b/tier1/wscript @@ -0,0 +1,92 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'tier1' + +def options(opt): + # stub + return + +def configure(conf): + conf.env.append_unique('DEFINES', ['TIER1_STATIC_LIB=1']) + +def build(bld): + print(bld) + source = [ + '../utils/lzma/C/LzmaDec.c', + 'bitbuf.cpp', + 'byteswap.cpp', + 'characterset.cpp', + 'checksum_crc.cpp', + 'checksum_md5.cpp', + 'checksum_sha1.cpp', + 'commandbuffer.cpp', + 'convar.cpp', + 'datamanager.cpp', + 'diff.cpp', + 'generichash.cpp', + 'ilocalize.cpp', + 'interface.cpp', + 'KeyValues.cpp', + 'keyvaluesjson.cpp', + 'kvpacker.cpp', + 'lzmaDecoder.cpp', + 'lzss.cpp', # [!$SOURCESDK] + 'mempool.cpp', + 'memstack.cpp', + 'NetAdr.cpp', + 'newbitbuf.cpp', + 'pathmatch.cpp', # [$LINUXALL] + # 'processor_detect.cpp', # [$WINDOWS||$X360] + 'processor_detect_linux.cpp', # [$POSIX] + 'qsort_s.cpp', # [$LINUXALL||$PS3] + 'rangecheckedvar.cpp', + 'reliabletimer.cpp', + 'snappy-sinksource.cpp', + 'snappy-stubs-internal.cpp', + 'snappy.cpp', + 'sparsematrix.cpp', + 'splitstring.cpp', + 'stringpool.cpp', + 'strtools.cpp', + 'strtools_unicode.cpp', + 'tier1.cpp', + 'tokenreader.cpp', + 'uniqueid.cpp', + 'utlbinaryblock.cpp', + 'utlbuffer.cpp', + 'utlbufferutil.cpp', + 'utlstring.cpp', + 'utlsymbol.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier1', + '../public/tier0' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/tier2/wscript b/tier2/wscript new file mode 100755 index 00000000..acde70d8 --- /dev/null +++ b/tier2/wscript @@ -0,0 +1,66 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'tier2' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'beamsegdraw.cpp', + 'defaultfilesystem.cpp', + 'dmconnect.cpp', + 'fileutils.cpp', + 'keybindings.cpp', + '../public/map_utils.cpp', + '../public/materialsystem/MaterialSystemUtil.cpp', + 'camerautils.cpp', + 'meshutils.cpp', + 'p4helpers.cpp', + 'renderutils.cpp', + 'riff.cpp', + 'soundutils.cpp', + 'tier2.cpp', + 'util_init.cpp', + 'utlstreambuffer.cpp', + 'vconfig.cpp', + 'keyvaluesmacros.cpp' + ] + + includes = [ + '.', + '../common', + '../public', + '../public/tier0', + '../public/tier1', + '../public/tier2', + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/tier3/wscript b/tier3/wscript new file mode 100755 index 00000000..045354b6 --- /dev/null +++ b/tier3/wscript @@ -0,0 +1,54 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'tier3' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'tier3.cpp', + 'mdlutils.cpp', + 'choreoutils.cpp', + 'scenetokenprocessor.cpp', + 'studiohdrstub.cpp' + ] + + includes = [ + '.', + '../common', + '../public', + '../public/tier0', + '../public/tier1', + '../public/tier2', + '../public/tier3' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/togl/wscript b/togl/wscript new file mode 100755 index 00000000..de8a3229 --- /dev/null +++ b/togl/wscript @@ -0,0 +1,63 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'togl' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('TOGL_DLL_EXPORT',1) + conf.define('PROTECTED_THINGS_ENABLE',1) + conf.env.append_unique('DEFINES',['strncpy=use_Q_strncpy_instead', + '_snprintf=use_Q_snprintf_instead']) + +def build(bld): + source = [ + 'linuxwin/dx9asmtogl2.cpp', + 'linuxwin/dxabstract.cpp', + 'linuxwin/glentrypoints.cpp', + 'linuxwin/glmgr.cpp', + 'linuxwin/glmgrbasics.cpp', + #'linuxwin/glmgrcocoa.mm', [$OSXALL] + #'linuxwin/intelglmallocworkaround.cpp', [$OSXALL] + #'linuxwin/mach_override.c', [$OSXALL] + 'linuxwin/cglmtex.cpp', + 'linuxwin/cglmfbo.cpp', + 'linuxwin/cglmprogram.cpp', + 'linuxwin/cglmbuffer.cpp', + 'linuxwin/cglmquery.cpp', + 'linuxwin/asanstubs.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1' + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = ['tier0','tier1','tier2','vstdlib','mathlib'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/utils/bzip2/wscript b/utils/bzip2/wscript new file mode 100755 index 00000000..92b9c0a8 --- /dev/null +++ b/utils/bzip2/wscript @@ -0,0 +1,56 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'bzip2' + +def options(opt): + # stub + return + +def configure(conf): + conf.env.append_unique('CFLAGS',['-std=gnu11']) + + +def build(bld): + source = [ + 'blocksort.c', + 'bzip2.c', + 'bzlib.c', + 'compress.c', + 'crctable.c', + 'decompress.c', + 'huffman.c', + 'randtable.c' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/vgui2/matsys_controls/wscript b/vgui2/matsys_controls/wscript new file mode 100644 index 00000000..e4060854 --- /dev/null +++ b/vgui2/matsys_controls/wscript @@ -0,0 +1,67 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'matsys_controls' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'assetpicker.cpp', + 'baseassetpicker.cpp', + 'colorpickerpanel.cpp', + 'curveeditorpanel.cpp', + 'gamefiletreeview.cpp', + 'manipulator.cpp', + 'matsyscontrols.cpp', + 'mdlpanel.cpp', + 'mdlpicker.cpp', + 'mdlsequencepicker.cpp', + 'picker.cpp', + 'potterywheelpanel.cpp', + 'proceduraltexturepanel.cpp', + 'QCGenerator.cpp', + 'sequencepicker.cpp', + 'tgapreviewpanel.cpp', + 'vmtpicker.cpp', + 'vmtpreviewpanel.cpp', + 'vtfpicker.cpp', + 'vtfpreviewpanel.cpp', + 'vmtpanel.cpp' + ] + + includes = [ + '.', + '../../public', + '../../public/tier0', + '../../public/tier1' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/vgui2/src/wscript b/vgui2/src/wscript new file mode 100644 index 00000000..951fd9b4 --- /dev/null +++ b/vgui2/src/wscript @@ -0,0 +1,69 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'vgui2' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('DONT_PROTECT_FILEIO_FUNCTIONS',1) + +def build(bld): + source = [ + 'Bitmap.cpp', + 'Border.cpp', + 'ScalableImageBorder.cpp', + 'ImageBorder.cpp', + 'fileimage.cpp', + '../../public/filesystem_helpers.cpp', + '../../public/filesystem_init.cpp', + 'InputWin32.cpp', + 'LocalizedStringTable.cpp', + 'MemoryBitmap.cpp', + 'MessageListener.cpp', + 'Scheme.cpp', + #'Surface.cpp', [$WIN32] + #'System.cpp', [$WINDOWS||$X360] + 'system_posix.cpp',# [$POSIX] + '../../public/UnicodeFileHelpers.cpp', + 'vgui.cpp', + 'vgui_internal.cpp', + 'vgui_key_translation.cpp', + 'VPanel.cpp', + 'VPanelWrapper.cpp', + 'keyrepeat.cpp' + ] + + includes = [ + '.', + '../../public', + '../../public/tier0', + '../../public/tier1', + '../../common' + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = ['tier0','tier1','tier2','tier3','vstdlib','SDL2'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/vgui2/vgui_controls/wscript b/vgui2/vgui_controls/wscript new file mode 100644 index 00000000..bb87e435 --- /dev/null +++ b/vgui2/vgui_controls/wscript @@ -0,0 +1,123 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'vgui_controls' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'AnalogBar.cpp', + 'AnimatingImagePanel.cpp', + 'AnimationController.cpp', + 'BitmapImagePanel.cpp', + 'BuildFactoryHelper.cpp', + 'BuildGroup.cpp', + 'BuildModeDialog.cpp', + 'Button.cpp', + 'CheckButton.cpp', + 'CheckButtonList.cpp', + 'CircularProgressBar.cpp', + 'ComboBox.cpp', + 'consoledialog.cpp', + 'ControllerMap.cpp', + 'controls.cpp', + 'cvartogglecheckbutton.cpp', + 'DirectorySelectDialog.cpp', + 'Divider.cpp', + 'EditablePanel.cpp', + 'ExpandButton.cpp', + 'FileOpenDialog.cpp', + 'FileOpenStateMachine.cpp', + '../../public/filesystem_helpers.cpp', + 'FocusNavGroup.cpp', + 'Frame.cpp', + 'GraphPanel.cpp', + 'HTML.cpp', + 'Image.cpp', + 'ImageList.cpp', + 'ImagePanel.cpp', + 'InputDialog.cpp', + 'KeyBindingHelpDialog.cpp', + 'KeyBoardEditorDialog.cpp', + 'KeyRepeat.cpp', + 'Label.cpp', + 'ListPanel.cpp', + 'ListViewPanel.cpp', + 'Menu.cpp', + 'MenuBar.cpp', + 'MenuButton.cpp', + 'MenuItem.cpp', + 'MessageBox.cpp', + 'MessageDialog.cpp', + 'Panel.cpp', + 'PanelListPanel.cpp', + 'PerforceFileExplorer.cpp', + 'PerforceFileList.cpp', + 'perforcefilelistframe.cpp', + 'ProgressBar.cpp', + 'ProgressBox.cpp', + 'PropertyDialog.cpp', + 'PropertyPage.cpp', + 'PropertySheet.cpp', + 'QueryBox.cpp', + 'RadioButton.cpp', + 'RichText.cpp', + 'RotatingProgressBar.cpp', + 'savedocumentquery.cpp', + 'ScalableImagePanel.cpp', + 'ScrollableEditablePanel.cpp', + 'ScrollBar.cpp', + 'ScrollBarSlider.cpp', + 'SectionedListPanel.cpp', + 'Slider.cpp', + 'Splitter.cpp', + 'subrectimage.cpp', + 'TextEntry.cpp', + 'TextImage.cpp', + 'ToggleButton.cpp', + 'Tooltip.cpp', + 'ToolWindow.cpp', + 'TreeView.cpp', + 'TreeViewListControl.cpp', + 'URLLabel.cpp', + 'WizardPanel.cpp', + 'WizardSubPanel.cpp', + '../src/vgui_key_translation.cpp' + ] + + includes = [ + '.', + '../../public', + '../../public/tier0', + '../../public/tier1' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/vgui2/vgui_surfacelib/wscript b/vgui2/vgui_surfacelib/wscript new file mode 100644 index 00000000..e3aa859d --- /dev/null +++ b/vgui2/vgui_surfacelib/wscript @@ -0,0 +1,54 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'vgui_surfacelib' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'BitmapFont.cpp', + 'FontAmalgam.cpp', + 'FontManager.cpp', + 'FontEffects.cpp', + #'Win32Font.cpp', [$WIN32 && !$X360] + #'Win32Font_x360.cpp', [$X360] + #'osxfont.cpp', [$OSXALL] + 'linuxfont.cpp' # [$LINUXALL] + ] + + includes = [ + '.', + '../../public', + '../../public/tier0', + '../../public/tier1', + '../../common' + ] + bld.env.INCLUDES_FT2 + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) diff --git a/vguimatsurface/wscript b/vguimatsurface/wscript new file mode 100644 index 00000000..2e1dd39c --- /dev/null +++ b/vguimatsurface/wscript @@ -0,0 +1,61 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils, Configure +import os + +top = '.' +PROJECT_NAME = 'vguimatsurface' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('VGUIMATSURFACE_DLL_EXPORT',1) + conf.define('GAMEUI_EXPORTS',1) + conf.define('DONT_PROTECT_FILEIO_FUNCTIONS',1) + conf.define('PROTECTED_THINGS_ENABLE',1) + + +def build(bld): + source = [ + 'Clip2D.cpp', + 'Cursor.cpp', + '../public/filesystem_helpers.cpp', + 'FontTextureCache.cpp', + 'Input.cpp', + 'MatSystemSurface.cpp', + 'asanstubs.cpp', + #'memorybitmap.cpp', [$WIN32] + 'TextureDictionary.cpp', + '../vgui2/src/vgui_key_translation.cpp', + '../public/vgui_controls/vgui_controls.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + bld.env.INCLUDES_SDL2 + bld.env.INCLUDES_FREETYPE + + defines = [] + + libs = ['bitmap','mathlib','tier0','vgui_controls','tier1','vstdlib','tier2','tier3','vgui_surfacelib','FT2','FC','SDL2'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) \ No newline at end of file diff --git a/video/wscript b/video/wscript new file mode 100755 index 00000000..fee20855 --- /dev/null +++ b/video/wscript @@ -0,0 +1,48 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'video_services' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'videoservices.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + bld.env.INCLUDES_SDL2 + + defines = [] + + libs = ['tier0','tier1','tier2','tier3','vstdlib'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/vpklib/wscript b/vpklib/wscript new file mode 100755 index 00000000..be5aab32 --- /dev/null +++ b/vpklib/wscript @@ -0,0 +1,49 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'vpklib' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'packedstore.cpp', + '../common/simplebitstring.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/vstdlib/wscript b/vstdlib/wscript new file mode 100755 index 00000000..f97ea542 --- /dev/null +++ b/vstdlib/wscript @@ -0,0 +1,57 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'vstdlib' + +def options(opt): + # stub + return + +def configure(conf): + conf.define('VSTDLIB_DLL_EXPORT',1) + +def build(bld): + source = [ + #'xbox\___FirstModule.cpp' [$X360] + 'coroutine.cpp', # [!$X360 && !$OSXALL] + 'cvar.cpp', + 'jobthread.cpp', + 'KeyValuesSystem.cpp', + 'osversion.cpp', + #'processutils.cpp' # [$WINDOWS] + 'random.cpp', + 'vcover.cpp', + '../public/tier0/memoverride.cpp' + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../public/vstdlib' + ] + + defines = [] + + libs = ['tier0','tier1'] + + install_path = bld.env.PREFIX + + bld.shlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/vtf/wscript b/vtf/wscript new file mode 100755 index 00000000..154cb5ee --- /dev/null +++ b/vtf/wscript @@ -0,0 +1,51 @@ +#! /usr/bin/env python +# encoding: utf-8 + +from waflib import Utils +import os + +top = '.' +PROJECT_NAME = 'vtf' + +def options(opt): + # stub + return + +def configure(conf): + return + +def build(bld): + source = [ + 'convert_x360.cpp', + #$File "s3tc_decode.cpp" # [$WINDOWS] + 'vtf.cpp' + #$File "vtf_x360.cpp"# [$X360] + ] + + includes = [ + '.', + '../public', + '../public/tier0', + '../public/tier1', + '../common' + ] + + defines = [] + + libs = [] + + install_path = bld.env.PREFIX + + bld.stlib( + source = source, + target = PROJECT_NAME, + name = PROJECT_NAME, + features = 'c cxx', + includes = includes, + defines = defines, + use = libs, + install_path = install_path, + subsystem = bld.env.MSVC_SUBSYSTEM, + idx = bld.get_taskgen_count() + ) + diff --git a/waf b/waf new file mode 100755 index 00000000..919420c6 --- /dev/null +++ b/waf @@ -0,0 +1,175 @@ +#!/usr/bin/env python +# encoding: latin-1 +# Thomas Nagy, 2005-2018 +# +""" +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions +are met: + +1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + +2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + +3. The name of the author may not be used to endorse or promote products + derived from this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR +IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, +INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) +HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, +STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING +IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +POSSIBILITY OF SUCH DAMAGE. +""" + +import os, sys, inspect + +VERSION="2.0.22" +REVISION="9848c8ac89183c48b69d47e767462720" +GIT="3f8bb163290eb8fbfc3b26d61dd04aa5a6a29d4a" +INSTALL='' +C1='#=' +C2='#4' +C3='#/' +cwd = os.getcwd() +join = os.path.join + + +WAF='waf' +def b(x): + return x +if sys.hexversion>0x300000f: + WAF='waf3' + def b(x): + return x.encode() + +def err(m): + print(('\033[91mError: %s\033[0m' % m)) + sys.exit(1) + +def unpack_wafdir(dir, src): + f = open(src,'rb') + c = 'corrupt archive (%d)' + while 1: + line = f.readline() + if not line: err('run waf-light from a folder containing waflib') + if line == b('#==>\n'): + txt = f.readline() + if not txt: err(c % 1) + if f.readline() != b('#<==\n'): err(c % 2) + break + if not txt: err(c % 3) + txt = txt[1:-1].replace(b(C1), b('\n')).replace(b(C2), b('\r')).replace(b(C3), b('\x00')) + + import shutil, tarfile + try: shutil.rmtree(dir) + except OSError: pass + try: + for x in ('Tools', 'extras'): + os.makedirs(join(dir, 'waflib', x)) + except OSError: + err("Cannot unpack waf lib into %s\nMove waf in a writable directory" % dir) + + os.chdir(dir) + tmp = 't.bz2' + t = open(tmp,'wb') + try: t.write(txt) + finally: t.close() + + try: + t = tarfile.open(tmp) + except: + try: + os.system('bunzip2 t.bz2') + t = tarfile.open('t') + tmp = 't' + except: + os.chdir(cwd) + try: shutil.rmtree(dir) + except OSError: pass + err("Waf cannot be unpacked, check that bzip2 support is present") + + try: + for x in t: t.extract(x) + finally: + t.close() + + for x in ('Tools', 'extras'): + os.chmod(join('waflib',x), 493) + + if sys.hexversion<0x300000f: + sys.path = [join(dir, 'waflib')] + sys.path + import fixpy2 + fixpy2.fixdir(dir) + + os.remove(tmp) + os.chdir(cwd) + + try: dir = unicode(dir, 'mbcs') + except: pass + try: + from ctypes import windll + windll.kernel32.SetFileAttributesW(dir, 2) + except: + pass + +def test(dir): + try: + os.stat(join(dir, 'waflib')) + return os.path.abspath(dir) + except OSError: + pass + +def find_lib(): + src = os.path.abspath(inspect.getfile(inspect.getmodule(err))) + base, name = os.path.split(src) + + #devs use $WAFDIR + w=test(os.environ.get('WAFDIR', '')) + if w: return w + + #waf-light + if name.endswith('waf-light'): + w = test(base) + if w: return w + for dir in sys.path: + if test(dir): + return dir + err('waf-light requires waflib -> export WAFDIR=/folder') + + dirname = '%s-%s-%s' % (WAF, VERSION, REVISION) + for i in (INSTALL,'/usr','/usr/local','/opt'): + w = test(i + '/lib/' + dirname) + if w: return w + + #waf-local + dir = join(base, (sys.platform != 'win32' and '.' or '') + dirname) + w = test(dir) + if w: return w + + #unpack + unpack_wafdir(dir, src) + return dir + +wafdir = find_lib() +sys.path.insert(0, wafdir) + +if __name__ == '__main__': + from waflib import Context + Context.WAFNAME='waifu' + Context.WAIFUVERSION='1.1.0' + sys.path.insert(0, os.path.join(os.path.dirname(os.path.abspath(__file__)), 'scripts', 'waifulib')) + from waflib import Scripting + Scripting.waf_entry_point(cwd, VERSION, wafdir) + +#==> +#BZh91AY&SYqz?&_$e>V#/cgs`P#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/#/'zھ }Ug7Ч>וsF#/Vnګ}m;ni6-9m]Ц^W}{\#m\Ü֯6mNU`}w[馑黾>{y=oz8=(vkoJ=!v7P)EF#/҂Q:v}}f{ۨ u=z#/#/#/9lX]M1TE)Puv*⏦C@i R ʊ6٭ SU#/UQ;#=#/xg}b^.f#vq^M#/vyw*6{w#=Ʌ#4amKj BP)=6b܈#/=`$.ͼ+9 t_J}{#/#/#/#/#/#/;>[[QEh{S@#/ӧ@WU2nqZ5Zl0#/#/*΄JJ#/#=:vhl#/>7wyws#}#܀:Pv[7ηIG}ܥ@:>zEy֗|}t{ǽt{Ͻ}u>I{ma^i}{v]zw{6 w{xvO@4*WTF;Fٶîi%wnkKthaS]0yi|ve.ӷƀ;v=n=xDϧֻS{nwۻ{{|w+{={޾.ٻe}zwt{eZ{xfo_]sfGGlg-osoYKӪȋw<ϳcs>{>8}{GӪzTGzSww;|}ٶfufv-yvglhK<{^47g%Kwy'sׯέ}}k 黷v(*ѹkX;Sk+>wG*]V7voxdPZ6"X1IAn]oi{]i]}RG ͉l=z9۴0w*;U9#/*ze_w[^tmsiͨW;%m]ATvt#/#/gXJ}I.r몚ԠP>y,j#/T=N}n$@(+}}{ϽV8#/+l Gnmf{md]#4κ(zvg/SonAݰJ6P;WwUclϭWL^Au*wyʹEg#49vITIJlon#4,꜁{U#/ fU ]aӵ#/uqծϏݛ#/#/#/ZȠvݎDn;{*![L5Lm#4%|co>&Y6Ivu{ƮƂwsݻnJ%h#/=#/k#=[#/!+mBs#/;亴KEWC$#/r#/#4]#/Ԩ#/#/#/==#4P"m}@p۳O䦛|^<4Ѐ@@#/14hLL&4)ISz2SOPP=GJhA@@#@h)ҧ*x§Oz#4='@P#/4#/#/#/#/#/#/$"&@50#/M3*z5FLOO64h=M#/#/#/#/#/ D#/4OMM$)Hf5G=' =#/#/ #/#/d#/#A4Ѡ4&'ѦL?ВzITɣ@#/#/4hTj"#/4LJx4LA4icQڀ#/#/#/#/#/#/#/?dU'#=`9#=G U7?犧DHS:J"J@@ #=| 4QÏ6/h{"zN8)[ɛ+8|ojJUND].nStLATRO}#/Sƪz *YC@K1#= F0M7UxO4‚7=uu2T;MM\/tPD1% J7` Rl'c( d+B#=t"" #=C@BiYJq#/@]*" _ܶ?x#44T1#/ P RTT"Op^$&T+ BI. 9CGQxDKSCHSE2pU0&),DpO7#=5 WU}((#/Q(DRB#/RJ($1D1DQD1TEAELE1TD$4UI$E1DUDQTASQ,IEQMLDSTS5QESMPLEIBST14P#=Q4E3,E@5H#=PPST$RJ̱#/)3!EI$5Q%Q$ES00T-D#44S!PAI##=İPL4TATE#4DIUTTS1RL-#4#QDUUU AQ TPREKD TUAT4,T$D55S0RP4,PTTAM)TCCS5 EM#4% $Գ5U#44L5*A4$!@RA!I2RTDID%3PĤMTAR0ASMTPA)BI,)KPTCI5D44ST ¥UBDLQ!"(B,D@34DL@UE4D JLTICPQE-,Q$E)QR2IAIDI@SPT4RS$@LQLQTEPRTAUPTUT3SU)Q1I1Q@EU@DC2ELDQUUMLERHS UITD1CC0!M%#4LQC11  C!DAL1PT14E-#4U4T#4ME#4UA(RQCE1)QLEA-DITI-QQL#4DCMPDTQTDQ%$DIDEQPSDQQ1D-DADMAEEM0@TMTD4 EDAC1Q,0CKEE1TQ!$DTDIbJ&("(%(H("!")IbJX("#=iJ%H H!)X X*@*X* &I* a""**Ii*"*`*& (i iR"Z(d&")Y$$#=&*I(h%bfjbJe&))&f"ibZ()hJb((i"$)#=""H%)"("XZ#=#=Y&(J*"*& )i"*Z H "Iei#="#= "(&B*Jb""*"e()"BH* jJ&(*"`bjJ&*P(HQI`)&"h" *"b"*d(#="Xai)B`i"(#=%)"(afSb$UPd #/jV&a bY"J""&#=Yj"H b*("bB") #=h)*#=je"&("HH*"&&#=")i*j)(j`"& **Z"F& 40J10TMAS񳉨Vab&Rf* I(("I)$f"h (f$!!""hb)&f( ()(`#=hhHi %)"h &( $B"(#/$ jdb( aB*JB$ a `f**f"#=*RJB!"RHIH%>r(ii#=b*#=") ""h (R*bb$640LԕS5ULERE@D1QT4IUQ4U3TRM%3L̥#4H#4(55LDC4 EQSADI254S251IEḎU2TULM%T0ԴPCE15HDUE0AUL)1LRQ$T05DDMBEJPKQHDHQA4BQKE5UD43TM4 I1LC T%!4DQJЅ#= 4-S4BPRS4T%1$Q!)M,#4AUBJ !T!#/@PPITMBRRT)C0BK%!LPICP,I%L$ %Q0%D LT45MKIL,RQ0TBPMU!$M#AED0#IDP!@4-RQ#CADBBRPД%+CU0 U-U LIL4JU)3UAKE%%Dą1Q1MT QT%)4HЄE-#=(JHPMQDQEDLCT%R@24B!24LQ#/CL%T#3M-1$Q#/D, EBERE4EPUHLD@RQCADSDE- Q- @U!31,TLJ DPPDĔSDE#4,E$0!SADJUTL1DQ BUTLSR M%M%C3U0CQ4U5TČTQA$4EAESIT5-IDD1 IDTL413#ACDA1I4 3UPUTIC5@A,ED LTUU4QKK0DM#4TM4JQA5#4)QHD5%!-2IK#4+CTEDEALBPPPTHUIA3DIIC0@L$SQ#AC% E EM!R#/RȔE)0DTQA1MPTPRAU!PEA+Q#HIĴTQ,1)10DSPE5C2!$S@Q@D1RAUED% R5%#44#LԕEKLDK0#445HD#4UERU4-TAAALE% C QK E!JIMQ IU T!BP5LUTU$IDDЄ3%D1#/R1$ITATҔQM+5E#=!T0-,QE1%U DTEUM%2L0-!E 4/6hbBh !#=bDiHV"ZX#=#=B$`d)h#=( i "i(Hh(V $"&f*(J@#=H$&Rh*HBj(!Jb!#=#=X a)J"iR )i@((ZB "%i$"h&X`JB"Qe*$( #=I(Z#=BHh h(RH#=Dd#=X$Bh(*(#="bj I*(#=i)b@b" Y*(#/*j $VhTjj((#=hh()i$!)Z#=P&"iV)F $X!Phi"`)*()h("bb BPJ#/O #=J +!bC>?tZUW+?WIms1gdM~M5 T~`SL P~4u (\ۨFz 6j#=~ĭ2R꭬m `r?nk#=mrhM8ԍr0?ھc zBm 0ff?U PbП !ɝS,#=I6]zT](/' Iy75wOX+C#4r<*Pth֦})2= n!V@?Q(~](z.T,Nu넾ߟn׍U֬0:rڻbg :w6b i`G=ȧe1rh8*4l&Ac2VFUŝ\jZ}P2oITнŘBR(T‰Z72%[G(g$ݧA8Ct,ͽny]P |t'Չ#=̴MO&|<Ȑ|߾;4p$嘕4γ";o) &*d >9ĈHjaK[vIlIO'+yD})$l*Xq$&CtKKEBǩ{*BQ-&0TGN#/@aMp!pXP:UP(gڷfk̰F{ǿ0 )2 l^ը^X$єY k\D#=9V"&ý69_]xZѾΛp!khi#=/aI<)AO}SCz0=PPL,̢M i)^=3臵:͚x9tiʿL bJ'&Z#=5r8k#40b>z2}X[xw^t#/S"v偺PZ4 =#4XfqRZi7fFHDr#=)t:lHCˎeGWK8@μ$W>ʱ e;vUiFk[]iGfLYd>JR #/z;Q!h^"4#4:h(J2+9ELE\}Lۜ}^ifi,TP2kSuy} xT;9%^ gѣfՒgdgQRn]mjJvp &WԆ>#4V|*ooy(뻽e?,SrK?eP#4h\sUeAs?v(|CgeVYl(@TuK:tŇ B"{%gk'->#=iB C8juAS #4ērQHNS^9#4\ #c#4F֚;L@#&Ŗ{n>>˗-grz뚅SLM&ҡǾluQ8xI%ww?Ǐpd3T%(2]R uJ^l>~K&YE S$G[Z#=Ei)$gϝG#/vp}t{vO^vb"BQN.c Sծ&+ )'>]pXrL6,d#=r҃ &!Z'蹖A7ZIE/n ۳Mq$ۣ}P+kY#4CSnFU#fED>(~6#?+a,R'Ftj멘;!6F$ARL )(Kb$#yK7m(f, HL2= JsQɅg%R޵M&D W{qtWX(57$N+("|ز"0"B\l4+12f.N|<GkK8>€iaS"QC%];ֿ~rh?#4 y&8qPkE#=ͮW`F9m8฼S@TG4VsR YpxlWPA/F@1J=KB(4`vgY Y`wژa[JVOպ d.n+N.ˇ4:kЏ8啀S6b]m_?6b#/DͣI(SQ1 Dr ;Zv(#CMg$fz@l#/x\4iDu:)P^Q4zգd>]I9k7_&0`+@ф2( #=Wuc͛;!2`xr/冺#Eba#4#=<d`NBd\u Ȫ#_uBjS3(#¥꣝T"oUӟ0qX$3@r`Dd?1#=I#cy.n="&ص|˯ku#=!󍻱㝬^SD$6_Բ#=HϥOc#4_q(}/9`}g%xa5!1m?֜z…I'QIzI8hOYxV>缼3O)HXwfJ&}ZXU6u#ְme5gaUGb'!ӥ׊StS;7ɐ(T-;/v/ AQT) o4N#ʷ[`x_3$E2bCpcsV+ytj DPz>ԩgж8?x_~9̜ȟ'b5317zF7aʬk?U'ZюG p9]+MܐJYYАT*|^ܱe^KcN#44,IP #=pJ(+H=9H$ڔa7P!4*k&dLr][ϞCc ` @B#42B?!7wl0],NmBkspsxfn3 ^\$H2}8J(ZN#96$:4IG29$޿tuoYW)j!t,LJr&֯AbKRJ3BhF#/N?}9P`q1)ʥ^{H4%!a,#rGzkb?LpB,bd²ᦨL>T7q0#=_#/q[YP@ `7g+nu.y^6@JUYq5Zx!XԫnwqSZJdE$2ތ<{ITinbм](tϖa4"QT8&p#=iTRc9D,J.x䡭ղA#4d Ѓ|+#4TYP=4}1դoMFZ׸#42!(+f =ˡAW0ݰ˭3]lGl{u ”|jT{㉫cTQ0ao>C~+:{Đx6VjfBAoN27 j4|׻+,{QʏJl3#=T\ʪR5 1d(MYQuquH1~#/Sh1Tfvw硳 lޖ>ul`JYs!&L]0捛nKU>ծV!CGBo>{Cu25!`/G) "(W-L#4KJl뿧!SM1X#J_8>}"ZT<>Ŝݖ~j5q@4\?y_wwA6i%>BϏSɐ^Td/Q7k"l9_N2/(LYKs|.g iKըlqu?R[Bÿ#=V^~np~#=Jp(0_loĝ9~:cconR& #/ 'uL#=j2 }JWZ)09O}\i>0'#pf9i_#=VfK<CCjR)HƒAJy<S$b$  Hb>i3PUvfĂ.\>C;#=U~QB +.u/^L݊B. d7Cvh!#=k+(Gwt-#=,#>MJPdb1heU"ف jk`dX])x EX4L~ldF:37u#=4_Gߟ/} k_>#4Z2;P6I{Noŷۄ#/^FDA]R*7=1C$/bp#=VЇ-5<'SB4'%;@@ۆ'NRC{OC-q%쯪Eg؈rcE#=JZp`"矏M"f" | %"'fC-RUE>Bc#/;Kؾ(oګniolW+hk.(]"bfkwx&^IS9'щ)^FW(Ż%74<7eൈkn#=a&fw84tU)O:(O #=d#=U|J/;#/q@cnb촂=Xşh@{a2$s0c0@Os;lx8$/kzڪ3z-0 2e"{B oLHf.|Tq[A}U6uX)bntoLG}wn#4G]%hV>EJgpΩ9`6[1[f4u׷M눰)mORLl j"c` y\]LHAVI^(T#uS-얀+#4с׺{5)E\hTPm3Q~^5?&}~rdHƱ!#/YT3-L'^=NfL7#4:ꕩEFmՇ0Hd#=t⑐W$ٕ</ .*.x|Ò`_p#=HvWS%Aձ7^9R8Ւ8#=:PEEt.ջlW St;qA[8SF#,|ܬi|&(EmLj_3s8V2531sB#4F-a°,61W |?kQ>&/ˈ}deȦA{w3Я`9LvOx{)ӻl}c21qR.ߎX$?p)R-rcqjfoiktUf'J"-릘KPYJ;*5q n_ڟ\W'>f^sfrb(}f2q4#X,Fs*#4m1Hbo!3dF6J`=$J]3n6V#T$d-э3fyMK3/_.q+lGqѽƃ3qU`]Y;T$1yz|3egAJܞWBwfI)2:}A~)YK%rn/A.J}<._ط61Uo,VZ-aͲt~yۿ[DAQB!E.EM"|=P$qUdRz-2k~qq+8b#-"j"*Tn. K3#4+]SJ2;eh0u$0+(w<*icNʘ*eڿb *æNK(=!qi-~/[;kf6CTX U.$|n'D <Zɮ###Q9l5#4v>(g)SJ5A6szWMP @( :&bT/}eHڬ귘/- 2${2%AG_vYGuJCJ9iTVS%xɒ/I;vHq>,LJpZD(gw@zunσ{!n$5(Qr oݼBbPo)o#drkNT>78@4K8`@Iө~krsi א3£ ^+,.ml#4#4m<'g\LY"ZP'6- _Vpg_\,yL{ڝDq02`p\8@^R1a{.9snf#Qx@ 9+5RO;\7?ON=jֵB¼<#4_/|<BgZMBm-ogxx6ÍiݫqرZ=ukKWNVamr>ڴ@(]t3P#=Ixv&^Sk9OO|Kp˃ƶyO{tL\ܢ]Nа#4P`wyKŘ-#4_dG.܅^⣏rE—%&MRFlɛn.pQ\:ȜEp7awYBx#/iIo?kF쳣\7-+vFraj/_®+؅pD.$_08plYo]j&M#=Al]y/{,2NѽT C(#KވUWB_ħ!6jJoEZ{|!ߒ Nmo#5 Q3#=3- #=+lMdD0`rZF!>6rIo4Cr;N!uCvw99~s7Y _ŤnִHg!n!z\\?qm+y,Fbz*`Q9M椺_WP^MA#/I;{e%` '[k2mdP;V`] Q †j>7X[ry}ʐ?Utu"=F`ez#;t_ŧ?Q^ޭ+SCH!UXGs躎!gv8 $>o.˰Q^{H}#=Xخ ݓ۱t*d ;w%]ix_veH%q3Cs8i#4~TjuզC_rSAo,]ABKYL^(U};×3&/#4I2ڠ{:ܾ5^jsW-swFFWtT(໏/#=b!. Pbj#=R(o[`6KcAE^Y> "zv-ӲѼ 7#/&ί2r*Hp.Q#|"9(P[#4EgP#/؀ S@w2!>NiHgY1*ͼ >?w]s߃[e7d%FE~ۭ/' eNMc~I?ۇ)@g #U@H}C% 86'bS+u#=55JIk^B喋f.ՃM6@|xTv}O ^yS\b(\B `n,Tdʨ#j1ݺûF&2ab:u*GHV #=#4I Hz*:K#/HHqs*&vn3Q~/&[umÁݫ!2:vJGvf!dؒpd(JWT2ERJUg秹3Lf<.#/|0Ơ|V $!J#4芟I}KR\[r ƃ-&bFQLzjTh:k& LIމBD5IL~,@"+CL@;Gͼ_ԧ%JfosFP5ڛet[6N0AEh%i#4/k^]}LJ;Csyzat,I~dg}1u9#/6#=AO?: /ogP^*W#/7FPp9@vyeQY=>Ӭ Ӱw|@!^ z/9{'hñKfƠzqiT\^8)+ѻJsb]Ntqͨyd=~hPy[U)#4ws-i=w9E[m8za C_KJ&-lcu;c3]4eʜܖjM6t7aX{W>FO#4Ӂֲ495+d[{k(IQd_7xLV9$TmGU35EJ Y @?v]|d}4u"@:$0}.όj<aENs@#ъӻovrWa7>$=wD3h#4#ITR4 BGm~Xu>wz#=4;.Hk1+P0vCI"hJA BBn\;v#XjsxAÁ\''<#/{ו-H{#=Eb*#*e:NGG7nYσJ#4N.v];YbXe A;TKIEE$]WV#=tIUm[*]4)vn3^t W3;|8E\#T`3 gt3D71a)`q\a( `,lו)7H `tʥ7urh)ǎͳ @5n|}7 :K4&lSHnk7,`CFKqE.jT[!BG8B@g#/q>[4E)^ LKfwh#Ga1fRC<`:L&} B6T&(cY/R4EQڣE#߬<{H eHHI>yxU@60h7~k8;X sՋGO*gHZƗlGچG ބ_C"Q#4xj(Y*#3&i.~a.G#49(efbCv=tBOGgzcוcf`TVN3قDl`t|abljCfC&#dY&oML X(ȌKI˚~rf)<ϮUXBH3Ы47I=y-ZHiRьX,gbXXL9.+o4R= J )79^E9cŭ FgHF&kEdf(g!dR0tum%;#cpP\Ii]p"*or#4C]`XAm!V"#=QP+XN4f#=oG#4D#I^&$盏,y1sɁ"ŗ J^Ro#4Thจ\ (-MC{a#+SSp\r*k*G/,BJ#4pҀi3mT6d薐81MF3D%A#4жt.KIIp#=S 6@u*#4xh &Pr1:pbňсX i>a(:vCh4 ;|EA#jj=٢O'#4ClCͺ(4Gډɨ əU?}jHs} bOo٬Ę|R&#/C17%/C.C~h$gb lBGd|5/}s$Ӕ1 ޽zBѥC@^-ÔR#/t&/Qj|)î_c#=AwscK[tV q^elER#/O$Jd#4'.~Lc\| g`?ƙχ #=$[y>ٿ\䝺i\s:֡ZsdǠEһZpB41D|Pv5h\9m*  INu~ϭE~rd40C32>U{'J+#=#OQHPo8*}տL{>y}ܢ+V[)ߋ0k##/H}䤖c:Ըi_/VL}Oun4YqQɫ wz]M~ HI#p5Nxv#&#^qzEyF#4pj#/Gvi _j<є'ǘ{J#4: :N[hx+!#/N &l2QYy X!;bj.ߣ0#UKM 7#4%pƚ-PjLc?b=eezܠ![s D -\""u( P8rŖ!B|>cbE׮jf68Z*)#=\׻!vĖ0P;!% tUC}FjV"f@KA{2I.\/KDFT_!U7éOY&abCMQ'k'b|axT3@[uDP#4_rO,#/5N_il3A[4rR1YBEbz< 媠rvmU n,sł$:ں;YC.0rĘ4QCͩJB]162He#b4J M#=y`t)PqA#42mT( NPBvOȤD{0jo[ޏ=tĎ4~7[#=]yeDTމyQoZ -WLvsы,Ӭ#< 'n:1MTLoTkV &4K D `$AH#4O/*N+drHt2[͝"PysMO tH|5zͯc 4 Sc{g͢=`8pJXBbT@QqL­NmOk1$EoTbSa9qu##='8dfMbqT߳ܿØ1]忛g[}GS`IIBA#/o[-$hsgK/HN(A#=e}K.{ γ֙$̓ELg>yRQC5?U_CHW@$C5:n7ê¢go1ַ˔jؕ'x,17nݘT@ܔյhVLI '.m뉬$i\us̓5=]Jʢz87DPܲA~vL 5MH#4{}\ÕG5[A(<5ѳNU%C<#raE8 0Į^]zz1'mZQ죖[ē_[~λ>,@>#=#wRKSE,f]&;~?-ʥ)~K7>_ 4b A5e|ON~ nVBQ#4]\K`ϣX!_u ]0L?qwW7-1t1^8#4^xx%)҃mc4) 'O.!vꚵ[g wL#=fq#=ӁZ6+j^Fox9G"Н5?#=?1˞3n.#/Fb󿉐 =jӰ`0J0YXbg8*<QIE.Q̰$ ~Q]nשd ]n=p 4g3v:9W3/1vdk:#= }-9̩;KAA7'iyȈ[gIDPE#4[۸Nt8}MG {-AL焲A^E4/u[s!)?8#=8qj-ՄҺGe"=C#45nxhg"BE#/&0W {vF R[q#/49'uI*}M6jQS`9yD3.a1ak,U`a{}ue٬6;jqG*6#ˌP(y`D{eu8!D &Y`K1>@#BUwCӰXysܐOT^Zn) ka|(-SHmZDݦ,Ab)I P2D8@oe:9<(#Aʣvr;w2YM2F [kKtP/@Lc)CZO7@qmM-鐛Y,)Q* 1bYFQ%/-LZO1ϵ:}o z;{Y4!vJ lbeMpd7#_ ŌۙaEٕvS-ᱍqgQfu1l@lB#4()bƹud)Bצ09k#c@(_Jk_gYlKVs {ㄧ#4tS;OTF@#=Ċ模t^圄fv4lӘJ2ن ]NBD<>/xv/" /Z!#so0ë#/Ժ&%M]\#/2PD$1#=~!tgjsxRw8 =NmH-uq&h Гq`G@[5A@ٲj-hH\ē$SG%:đmѹ#7 Ձ %F2C \B2t_.e#/I&^vf!ȏ-}E=aQYԊgڕbg$^k!JsUkbv9 O$tL8aP4l<2`.H.7b2ߢuP[6[s:j+R@ra 6m¸Qg=Dz 7Tyw՚];[2%&^x4o?#/S!etQ^VDc̗o᧯|lzWg ZD͆#/'PndFn g[Zl^@8\1 g"cQ[qAR€r8 h2/p?G`qτeP( tj徬eŽ.{r"zAx|ǛWʹ`d: (/ҹVpX_M2?C.gM\^on':?tG#4QJ({"ve;DcUFUq\1a&Ϟyj"%$/[>fa2ha#/ puqˊ"3FGvD@rzLZ}ue@dj"XH@ WT MOPTF/Or'S`6ʒdn^s*]tߨÄFA@uooӃAHj>O/vxE~_>aGp;Q'bx!#maŸsJNH A۾a0%22@n?x6ɅESZ}=?8G4\:گ^ݷvQOЛjzg2,h6옖m3#4𓀼Kn׍ҿ.A=#"JԽO٘Y5K .;t#49ixCG(~Q~cHl}^$;C U:"vY/{zSRDj<;tC%bHv&#,ʼn)+f(n_`eGzv^ @#/^,7XTϷ3t2deZ(*BE]_#/İ^fDPz-OA#/U69FDIItu]#/#GBb#4Y2AAB$q_N}rQvW)0Ϊ56 Š/ p1`rᗟݗq1(g$-_!~E+m_'}6cJ0#=B#/';}g~_ֵߥfo:߻WPWj;F4 "D~ 𑱙,ǫT)*k3eRmJFq܂*RsF[RG T4#/!ON]qkuAL *0GdE(h}P|k㜁m/vyu.tۯ!ӭBgȚ#,J(ha wΌX;ɳ0k?TXvEssbe#49ꠌ!Ԁp>3mMQ QMw\_'5%̞_#/M< )<!c 4D,\-%p%)O/H"K|%F#˰᧗?6q1@'ti!6##B{A3P@D8a^*{sM-aIGlHH//,_#zCO/gꗰـ:L)i.R'uߧ+3w(QOMT%]F 79fQC-t٢j\Gtbff)Bl-VUbQ%#4[Wyzت{7J`OzzX433!=vD&#J/mǐ~qOs)`mOvLDnu票Ε\sβY1kzPU3bUV]YºhJG ^|>c8!J:qÙ1ͺh#=٩©g%42F,.َ(Xs8pH8\e#4y.D8&5+z) /^μZfψ}j+7a`FJ,`#46$SYPyTh%qa@IjzA]Z0Mw{TkK@24+^GAQr#/3cI kxX)<&؇.+_XdT)nlJ$3bo&R6RYWWuGKvn(sn,5j}_u#4;<&1iGRfW-yz cmخ]#/#~lH#4z|~a j>D{%h|m[%ZB!D5H-a6l9p(M|:$A};㽬10DS>U#/o@ x+!= #4'h &040!as)ŭM(CL3#4KIɖ2Ґ8p+JGD62_tXN&rNx7{2>8$'e?#:~;P6c3Ҩ]ҿrL+6fLF[)g^"87I~\I3m I&3c&0\G/V1}[>;j(WH^&GRסg'R|R)U #L35XBB`gz[ G\1Fo31T48YͿu_}ѐ3ulL#6nLB @__?Ʒ}; 8#4KpHsiA>o$7qz>=fKFc!9AC O~~geԺ,c: =,(X۾W26o+oY6s )dƆ#C֜,%aL$$c֙kU`,ҦZ.J1I$$sE/Oȣs˶V٫&$Na|> QF9h >X~^Y3=?F{@0#4oP6ni5)jf|:(!-50n ="x_dɟo^ߖ0J&CTG!5V@;#&fMI#/G#=~!c]D,R%}x ]gbncZ@Ǯ罘iGWg0f8|Z4dkB=_c x$o<_p/>;CsW'ܦ_L5T4EB*#=%SueS7T,\3wnti}\ǢA.g3,,g#4xZ0H6.Q.7.1& 7\(^:%1Qv#=f}; i#4)XwŐ*E/)d!,ju18™orSRDr];NMdΕw*Q$9j@8<ȓ"\~A#{*}z-۟AK(l% |b"I /w'8U^6E\N|R胃q?L%SC\4_#4_xo ̳r>H8w0j72E9C(,fyyṊJWtpzE;on"\ %/Y0z >'`ۇ1T"8A#4c+S (0ZA-2Lu&I#4v;"!S+ܮi3T>mW,0N!hAoTD.ȞPs3#/r5~q 0Rf#4aM挚+ÚlY+CǤ8K巍qB-U@W|$ӝ#=ZĠvjTj<|j<ˁ$?w&A/QΩ4]I#4EKmWrM(D#/o*/e^e@:<'Jm͑K"XFֱZK:#=bq1QHô`cc,#4̎siWa|֋1e:lCкbra8vL?I$ k矇;l1'/b_?iꌊFw<ãx=>`=Id9gFwXfsa3"#/~r" 5S'iVMhܴnyϤh\_xI.-D*#4X d[PzE=TK@RA#L캓xC:{uצY#*;R7HavHn̥kXHV#4~ݳ c01U  Qb@#=v;Kv̩~G}PgUV[z*] wW}`l+RʷT(CP>1U{f+¦BYpjv N/AI7DF42@}ͬ;iҍO-e'wo]g#=(YgT ̄#=ysX`Uw{9 v=8hk ݥ̰mmgP@&ѓ`tb:ft&BXAc*} ^]xF9#4J'9bܕE *.6ħϽ 7U;(U |u%5I#=>|-Ƹ vesJjr>!CR#4Yk]b-|[٠q >OsZ~O lw|"1}1aqmBDyq~ú>Ry?` >UqwRtRW[,}s6_#4J\%PP{|5*Ŋx;7`Y#4)t/EwQ)7VF$̖I0V&n91w0(U8F.:8;M: 9^Ngj+tը37gBf_EļVL$;EaX:ׁ>˗ a\8+vƦjAJu'si$*J8DJK esS#=LN\0nBM[x3CNvϜ [6A)g#4= R놙ba%Т DŽ]@=FyMپ1~i;׭>_=怡0U @ِRm'(鷄~9SGnw]BkGY# pmAHZҶĸjbT5 EXG#4b܌+CL5֨[9Q(&4Z9®[`10z#@FfpJqA9-8~=#4Gw ~z.S @:#= eZ`l ol#4x.-a>6ݽUrb], 4,=Y:9>5BfߚJXnZtQ ʐPITwF98;ޔgX UsZ,"5Z^#P#4 (Z=idqr4ݮz96t#ƒV\5̅ɟXQ;}-zrp ǥaL{g|\zE2*xZH$_ǡU"d!Hb=H';} U -t^k#4~W>뺏LROrcd?~?V졡$i|^t/#/(5 [*O6X)ٍd4"2mGCc,B?#ntD9e}cnkiU/hiz=rKp|gdN|e(#/"zdY=*B"@T eV(YE̻^.- )#4-⻖c!;/URe,C?neKdUOzg0AVV'dO`TNڵUEF"=OxH$o7aqʸFN#4~o= #4pCq.]p@VyB\$ȠAL;&@wq72x_8)`Y8A"S9 4.{?4/`sy ?Q6htpPP9+[~) .~BxשʥhYYoUuO ժɭ9~+ι%,/T#'dsaH#45S%#=;ib/AEWSjR" yQ026t3A߈3.Ͻ/d (X\;>9tÆQr9=B÷kB(v,_d^p9"|?[z"$f /?s/B뚵fG3o\~%?i|?(CՎ+ДLr4hmulD#4aL^?5 Q #=A`As,4/Z`t4s,AEEjۼsa.Y4Zcd BPZU;i=ݽmjC^>^w!Tl8#4tdeDVBAȥ[R#l||䐟D| ZS.*}f1>dN4/Wy3$UC_~8AhUYg8+YrW#4+-%9q=æb>Nv}M69B62y +-[k@\0mT& DktI#/Rf+r tFE)#nH*ҜwO, eh,e`%fp*K#=t>#/]^+*.񡲘rr4GP9/7t̃ލ;fdܕ>#(\>GSOlΰ]ڱ bQ須olueBWΰ ۛ~c*nl,dTNV4jٓ9f"gץ.AoQƐ~wr@vk爮#49tFLkm؈n13 2 Hvo>Uy|HPocxgq}7@#4H Qo#CGiWћ޻NA},:\!]\0$ԭVq0Q90G`p1}j otoԷbmM\+ni@qn+]~U^pc"¦!MsTo+wtLq[f{#n:xkKoaɏo]Ǹ;0`_fx=p1m}<#=ͮ=#T\f#=\8X8N+۸?t5^*#4) rlr 0ejh7 ModS,t(^nX[|>Y -`^z2/_|QH+CMؗvu bL*J<"z.DJЈX ܺ+#4qٓdb1PK3*0j9>_a74߅ar01/]8rC"ZUҒ61' b9Gi ^&p;1DZ3|PRɪt~w5 aNȅ تl퇏W玭faQSd1",IC6)Bhz>=>pprUaA#=M A/JxlO`'#<7&y;TI,l9tXDj߂; OIKA)a yhLQ꾜|z/Nq&.eRdH_dB{b8 ,g^Lq$9#4\iӸ%6:-Z^<J-'eqv_t:8f}'2wB3F)XkO#=BqۜvAǎy_GU+l#4-U-wVRc`PpȨc@_0!ԐXDS,XFC' 7ÚY51*qȆ n?18%Fvl5 ߘ彅~G|y0Q-9ߜ. DE{: sUF㲱7nd1;[xf#41e2Cd^`oTU L%9|p,=wNH ̞^l<1Ӷe.8#/*#/rɰxZ?y&B8 8VnkvB4L &ɓb_\}fKzț'{#=[N+;c$H`Q%fB!΄"#/mYx#4f+.)Nwa)(lH'd^2>(sUAP,S7#=a-{AHҊY$,\;1;^UI+OIv0xc#4W]rx1h%0ϧN@0TUkͧbbeh8'~׈&L y*X\eMDS@pß7~EϘ`lG9<%)񖆂 <9w8g~p)3?2x* NeW,(U\R̔3Nh=0%Vp6Y./!JD^ih^DTƍj)k^e]U.>O{oˉ/ 3A蟝{|:t#=U WBdWrcŠ4F Z;)]GF`79"\&3ڝW9ѣZİ_le=`m)Ib+#/$M#]#=}U砾!.1?q/3:Z\IeU]a"@!HA"\zРFqh6'/~f3 .)iT>]?T#/Ԅ#=g V7ܸE&6,oR $DFx-8iC;ꌃ7H4!SxMqT½y|X0`aTc8n[9bQp2fqQnyj)8͕33_{ǜq 627HidGK(9PNJ1nA!OSL…M%%-7 ,Sy39< Dus7HQXb~LU^Oz0:p$]E-p0cbEUT^6  Xh ,+>xy6<#11u)\o^WXiKAq]Û~ձ,-:dE RJDeiD₍kq hsKC?`FQ&mt0饆[BaB4H5xS¶EÇ>J3uߝPi~!EA::'AvJ5Kz1.58|o0Q::SeQtقɡţWmת钩fUD#=81'!3Q%a}V. Paa(!ݽ z1>:I!#/:ӴҟZeDoӟc.M6Hm[뤹Z(#/̗wu0(7R3;e0WI,OM%0U{zcsRWcvY,.DqjϓtHV"%0mBl20퀷hnUS(mXa"u`6ȑ䨨U>/vFm#=Խ:72#4œ,eP]q `0AW5fq@`;:{$X A_ҧj?\<2Gn`#4<yF@MYJLGAA,Qre]d19w8EHSA=~G!$9JE U Ք"Y\AT`!;K͠wϱOi pQ 33>~fVn.m wo"< rh?1#;Jԃ}y)mwTk^[ *4|]Tu.,"Ra_QIRH,mzmrJGԵt&6]p粍B%0SDTR_Sխ0كɃF/wb<\EfC#=n*FU$  *;[f+zuuqь>yB[fSW.lD#4rI-]hl4l&C.v_#/ #/v7a'ta@\Mqb>?Qxuzf\z(>0|xp%T(s2h*z0c߮`fv"}gㇶv>֟_ - ˿iCJhI>o; 8o[7ñZ+V/'؇Mm_qB[~fq&+#=U_&eʇ+R>}xWڄ,"#o'ի BԿxuU[<X1&o–'#4lf2H mUkx\2U4vY״C1ʤqInU?S#4+0=:vY)quZ֧8z ͹x q9ܾ[4Ŷ66G5q#4S`j\!`\S%.Rm#'gby8`AǓ]F!%uP"F5<`e?rd",w iq}Ovz3zҺq$7k^]\=s 湇N:S`hHs.6"/,ڳYⴣgefJ9#O#4zwHZ=s:þB}O M$ָܹ,k>ɮ#=k֔=z}xO7:Nzw-֍UVUpP{s}T;V >0*m#AU}*Z\gVƗ9Zuie/6Dv@3#=v%{,*q/k3fM(Ԃ\^4|uze=f_>7ni6-NW9Nw*e(y"-@R[I4,g#4F>un?EyvgGe.AXr ة#Hw>(g@(th#2k?_&Jl_1.: L)/v3w՚%KSXn-+D|ZY1RhgogQ>vO#\Q-ׁVi#=9 ^8ݐ!꛴& ZOBe)<J(UcO\+_s̚6I:꿆UwҿqNcqCOPxeǽĩfV2p a)V{œM.\Lv)R/ʟ׊{|(N̨׮1|%9-G.ZX}%NTŕصr&x00Cgho#=y׀n\_)2uLG^XWX4'_ܭ]Pq! =E- X>/q.^*? gf%IB#/r#/$\>r86S~[}Wx˘ñhKF'XlDs3nps()N""9E{Db6s6h&A(B$!!Eq#/m2a|Y@ރqEJ0ʹ!-F&b-+_2m/5=#/\:)yݦ&lsy^o]&RDlq bU:d9ĝN\5^~:P܉ͫ *\,1g>|pԽc-)r0A#/`U㜉KoWzKqꕝ,鱌m9[1xF=r璩yxq؊b9^/ђm^q*PC9$Ǣ̀aw#=8iH||.7J \X̠pH1")K9hG#=L૗JinQr5„X" TYS#4ᴌ韟U#4)g>1kh}F$DȮ:tzryiPb2аfJ#C዗nOiH3\[aj+,%׋h)f͋|J\Yr+ Z =}N"ãzp9#=Db1eZ O%8cICciz9Qڃ#4tC#4U,Dg{LF]bORЈ$cY%x^ޞX (t 0epIcue3Xd#=Y(BS,XY/ C9*2K$[r刢 D~'QB 4-N4l|%׿j&KqƖSik-x "k#ZL.(^PtuvPv9 #4.aO~Q|TDnz%%}3Kp Hd`g B\%ed<'t|~}շ<SWh<74wDAG!.Q"NLmI$NļA:䓟xoml^|P֙phb7g=j]8$H(d#/mC5Og#4iǻ5X[i8uQâ`a W!\ )cVn e-P Exn >K1;>RD6sPJhOIVa|QQBxwcY/;Zrxc8e]iY[zKUypnw\U}a=>g#4Y^x^XcIWGɿ}s:c9!wE}{pe~/k|N}ϩ7.(jypLz\:])8{<;MLǐn9WfDw+L#ߪ^PU$XU3l=cygM3'÷5n'.@?`#=/lQ]TC.3uq?ͩV!3dK;g/KJp $Qw`48-p2=<#:]]z)pu=Ӎ8a'xDANRʬWOg@#45 JH,hb^B&%")M. JWBd7={&C}j0XKzi#4`P@Z*"iOl$#/&%C5B \Aff}2)&^xC!jYvg BdLz7K~+.]iD]Hގ-!](û8~r{x ABPPOlؗ|'R~CJ_㮶!<{O|(*`jungo8(q:a#/@ ?`9ǖ7Uڮǩ[ن'QDkru[{Om'$)@0SJo{%=2&Ю-Р$SHx"yB}1[@F#=iAR Á$ED lB7K!~vij"qyx}#4nc# ;}c8]:~}Oo sRR?\#/w?8ӏE)+.s_$>Q2ۣo<0[e/E9 &Hm#Τ/ՀT%ہkU H ;˧}z~0#/P֗)"O#4(!9~O&Aށ4?J5#=hS5Cܦ$:~ ^w#=w}B])E<;<.y.^ccjݔt6s9d@ȵh4 m5Qqwz1 H@4,KDj놕iVDuk@D*%[KY#4#4G!:/gT@FO*K>N?166/.qV%-g#sh|chmn#4!+2#4, -c7;GKpE׫u\Ei0)5kTawWVl`ޤ9n vd[9j\8n(FQ3MBcE4QV}Dr}lR};-^ B!JOnd%?Ɨ(PPpEHUNݹr+`k;l%ZE;j(}k@Occ( uB#oHweR;>`(E@"}xXB%"J"hR8A#=?qjI񀤖z#=iv,g:ryQ8Wb h,64wi{T48ðD)TOh0$1ݴ:M7ql#=1__s),cwc.0mE6M_2)TH QRx@ЅCgb23 %>GvyW#=mD[0Q iؤg*ck{GV+D.?ڝѓJ?#C&8y S un^I6,pTJ峉6|7X30}|PC;Q3ECJfb|؆8#4gCێy,"C:W#='$K0~~ J T~~t|P?*0QܚoX@QQֈQvPW † )_562*LT,:#==4Q!2(Pd CʐF# Cz4k|oإK`׍?ŢN:vC<ݚTFǛsw;29Ȫߖu<چ2?S椺pUDO.dAJ]oNk 4}qsF{U|0ّ]έi׃P:kfϷ#/B1&ؿ{t1F1#=BnaHYK _~Hj,ûY˒ԄMJypP$`#/]tz;-7߻QPsu%Q?/#{UO\(.1g"R>CN_3YKV@O?Ԣ_"hmNj}Q(IuJ}brI~Iэ|.#=yh2;׋fFOL&;?7n /ɛ)ڽ|q6)Q+]NE(IZ+@u\=A(#="swyG[$qdPC1dX4G՗#/Rc$Fѿ䞢#45Ӟp^#4<ќ=/=~a/{]t4xzߨuwhk0.> wOV%1| 3zNj1&<.:fV"yB#=` y>zv9~S?ϿW^uo.bL/ҙNeRy3{zj=1ݜ":kS9w{/v==A@$Fbࢉa`T#4s!hb&"%my'ψ|7mFݍ#/_v+ E^d2'D8buMrj#YĂ#4@ O<>'%O^_'#4F[L;>Uz>j#/gN_5^no{E80_]Pt5~Glݤp5z>~9މm^JOg!E6⣳[:{S+q#=s~#xS~ou{>.߈6j.`xE??>K[0aݳ/Y3j>DQJ#՗˖;N;Ƕ6#߲L=՝>:}BO7柤CߧcN ]C )/ rͳKw&&)/aXN|n<}7/Ҙu0:DzSRɦ~v7cGV'mܴ?%uK#4B0./hn,>z9yXW׺1Ϧ럲]Mn;~Ł{k~yF^^}CD͆-KGt?oŷ^[o˿e^N:Qau.ݧOn^+om4,YTF%,]x`fYVj~}f$6}##4VKE 22`|\x 4o\=V)3zak5q&ӗah^M0>^o?,~立N[6l(=?%G_Og~hl []Z}K} >!'yύˇݴ~/c#8q=%֨>C/6!K9"]Oͻ۾B]pFwi ?:OQ,TRG>-r9qM^#=Knw>Ds;Qy83y>|xṹ2/|Oy~eWOOg|ҹ9݌qxTMGڋP$;#=vϹ_p#4>o湶̻aL>zrJ|?K9ՄJm,!1/O~Mw((SC#=@23mP_>ccO~^빛J-ͅe{bɳ4O.m&̵x>|QjL y)*#4NrR #/bf LWig~|&(?/~Yt]86-rv4~7m~sHaO#uuf{4ю||KvG{߈FT[w~"޽@[_fZw=Kz>acM#=وԪ>Uq?cKX|Y'ktm׫1/qseq{gGO~#=7|ãh/#Go7GgޗӠ7@#/GWʠB<@ss#/#PHr N.D%:[iNN7et7A/hˣ$z:FyG~G$^>(GTaww>P.~m%=qsSQ&gQTbS۞YVX|w䡘d,"hH'ce]#/#=D̏wBk#=<:SCU9>mܚç Xom˲98R&; 8TA DupM.~ 3E- "1w /m}[l>>< } V]z_0 #=xEۦuQ$864kB. -Egx=iD:퐛#=aK%D虣MA7-`z%&>oXnLcgV:RC{)vBDqzפɿ-y#4q*8W_1l6r#47#4{!MNPԜ mtLt|ڨ`jpb7tA(B`SqTmFZ'WŨ ,ܢ)1ڳ9w`aI$7>k}k#t"a;9k,pr3!G.@isRcC{#/8tX5xg!se>ϾáзAftUwAR~#=1lM4c6k^-Ň?;|TkWݱO8}2.d)K锆6 Q#4* ֗tuE$;eǮ>oH9NYEݸ9?/=|tӱ%[*o9:9A puPt[Y>L{Q?J5.ͬ9%#4U&'Q6r'7Vq mS#]>~2'XU뫪L26FؚmR2I9#=2?I7(VCIX9ˁt6yyr֔AQ$M*IAcNT ӭ<dh$8p#FHnY("ӧ j剒QP܊i0f1G$KvJ1R=g~=(8#/ӈRөzڹg6eOfw"< %#= (1)*//7Orc`I$% I$@^Gh66󁦏$b 1]߆ƞ ϭfֿ_pgyzyk`7鞰V]>K_5}6w5yͯ_?n<$'x?([~lXr6[>PoG˚C#=Llt']9W& n#sZ MYoJ-T`?~ju~k#4?:$#=Y!|_Lt;CXA>`-(ȺA;aMᯚ˥x WpGD5#4#(??~U/0ؚYURSjxYфr"!,ˡ[G#B1GۚyN#YQ g@չ׉DQcQLŸN)#=e#46^UqV[k42XicَLv4fpF|6#=qRLμ0-101\8DY#}<<}H\ЯnN4Ys:#ss<*#C^0wX2K l*b8+8; i=);{w Dئ6dƴK,\Ab ѱ!O_$ |X`[YJaJ4dr(4g/wL"}xwO=5HwV>a,qQav //'ObSv}rn)OߒV\(&~!;}CNnmBvAy.?JsD9*~F< xb#qyG.aN NܺCs8Cak#+tu`G˵G~>)(:O;#/>IRJ[EC$Pwਸ਼xN#/A&qL~=/d#4CUw?`%{#{K:ܥU|3WZ&*b%P{GUÔQ<5p-OҶ"5>QDog7a3p"wbB)+qz^'\Μ7bbI^pW68+nԧ#4qMR![#4Dc#, h1;was2pF[1njc#4A{HD>L#sCjK bjH&h$39&&!V#E zd!ҡZS1Tlg XYX1;c,TX"T=|ԐY f81UqHa6t"ܡ)#45BQ4h؎ vD\M)_QRqIMqƣ;[E_\ZqE2U3GnI:JA2`rdjvﲠ}VQCj#6c]S+uj mջUa~ <眭iZLnp#4쎇Npqޝrm&%υwCQ {#=6Mƴ>DU4Q+n[RVusSKaN0lzǤڲZcBF=w0\#4dV ٤x`5.A#43]Ǒ[[bɉ(UF0- }`Ar4#41 Qt#4h< f`Y0G1^s`)h#=-`$iZ-ftlFTcN>Eޛ(6+I8isAҦۅj(>>7jQUCDnε1QC?S,=8O[ܜ({NkQE1{%?3GĢE>jĄ1{%1A0v:mbb)>%| N~x#P#4)QGN!;iC8''3{[`O=:1 PVf#4#4OYnO_zH"~$_OC:(v.1(w~a.4zqQiz R[qRO$46Vr5>U;xA!4-Hdܞ)CmUBC(_~ͫǭLXt0ia֚m#4m+:LElCMQj)I# O4̑eE[ LdaxC"mb1$:;I&@#4bMi4Lqʔ1NB E"8nh- }z6" vi"Ŋ#={+5\oQow7Fz8?m a8|&,;#4E?]9j#4:Mc[G jC32(ksҏQ*uwMS~Wb)^ϭXc{낛F7&5]۞{=<]ѷv~O&,Kd!{zVn_'nU.;ml*-uWƆb#=J˖ЙKA]ݙTz%e%z2uyw.YOs_\+*zfXnD7 PU#=t=y&c1&e%梆/)9kfQDF#=BIKa]@QG#4Ói BxrMf˕{iC_Fdߛ3l*^(W/Qw~s%AaOR|~;y~g?ȶ#4wB}n6jiݧC)<V-SC'9w|?n߇3V:{X?5#/F"Y@#=6l_X`dZ~ڿ%#4 0+ܯ E#/^MU=^q!G(k o 홚QO&g-MI\o7#/cƘp[v>QtbJG-Ip_C#4 $<@1ێ> ]݉E*+e ">d4Q X_J`:#=#4$<3tp=.LTÉ`ƍc *Aw_njyů0$'.P(8jsB_HNwߗQ@|)DmOSI_w$I'4z8v0o d0-90g,2{ZhU0U'Eldϑ7z}SS +ZwEGiHĽStn1w#/y <ⶳ$I*"EF4=jxfOdͱUi%|7~ b̳3R4BWf˓ލT׳!Z̳ͯ#JΎ#4a'%hbVUqbfv8FZdچ2u30F\tb8U0~a}3Lɗ,DY+C& Zv__IFO&gZog o';;'L:`&hC>o&W|v,ųICK>g_8AS`_4QkȒ4[X󺋀b#/l.Rw=9-r|?eRi?@;bʃdֽ}ǧSoےY9ѲM|<'5;jN@PQU/FAUAA}h@> z#42eD̿>} jNrr#4[9PF&SIj!L,>DO\RNpˋ-&Q/mHR9pK~ʢ$7@`ԋy1Q]#73egJ~tc&bCZ+85>"W 桥Yn#=T㐼,QO41#4iJTxj5j38i͕Bi8R b-.RE6*'NH׉Z0Ha#4͂ڣ#= =hw>]׌#rU HxOA#4ɻ-nsW !aۿ+.:kEc'5z@d[d KDb@:ћav)U`Rt(#;(| `Ēo|6& h54rn>3ȴiwr艴kxo zNֻV ݿYv;si-2-q#4Ҏ̢Խx\9["g7#4=R.$4bF4UxscqLA|y\J_?=؋F%%%;%o{"G6OMБ\^L\7fhCD,M t!>7-D4Ͻe <5Fm5YLJwIS)LoOdxɼ–&[|/،CA1N,s^~NQĈI -XLNhLWZs7ҵsYRRe^;tOV%1"9j6~)h ӧwԺpN>kx;V&n3Dvk.ώB(YseHd3l{;]gWWcH is4muy>H:#=RbtfGWƫ/ L ֓[JgmwKw20v;a-V6F%ՓExJ4n'.rhZђy|5/O7WefrH[} Pŧ/Il(0D>MN.;ͦ#4nmYL 0&#=\͜,L/Q*{l%хyi͹Eh,H+YYd>);eTm0єp1"^wk'$*n;m׾O ڰ@.Y0+7*@{0LV˦fgxPņ~a֢l9XJM*Ȉ!#=]d\vOl X[o>l%پH`ފ/Yں#=|E@@ԗ<xeV$+sѶ'%#=JB+[LDA @.d]G>wGe#/+WXd]VEٴב|րʼnU06iզ-y\ #=/zff;>1ڍ}T@.m!HQFvJ`325d*4y~+.Y#=\uփ6a<b TpL s<[7Q0Ung:s;YUf^HҖYUXNL(6V3J_f#p|Z3h!դ:#B#/q:Ӝ{++޾_fq.rM"#t5;G)Yغ:_%rk«u@<trYѭbA%jUe4`-9o&.F/x{|^u;-nP~^!rxyGNQB'i5(>Fƞ8_T w7b3aSF[AlyC@(IFZ/Og2Lt4Z׿wjk±(Zs+eX͸87)G>~KI|$9i^$|ҔओN\˵ť4sv_}\Qݛ}ٷxU7˶I{b_γPv[T)νg xt>V: \}J~W;޳lg7UXFH #4'f^6Uqʞ '#4p#=p_[@3dDYf JqARsV=k=(qk-~4Øno!_wl0!=1^)a-DI#/pwϮ)By[1йT.f7D?AՃ4N("VTE АX8 FNԡ#,PL9xwggbsEg;#oa%NQ)j q)BiΧk8?~tˉ5#`*8FjVK\aixyFцYn6z1S߭YP]G}͖roLjJzO](Co|%#4WHSrao#=֮.x?C]#PHjZ*̓Z m(@ܬ~.o3V1=Tea@qgVҏ;k8>:D7I{w[(OrG0qlmGK3HŦm^Yb\8JwHm#OdmBTنM ՠYH}8?6p2~?WqF;g~PAf~.k#?K25mscb0#ωpd6waBzu]O]LkV0+WFDwu)FM"? \\0f&x3EFd=6k* Dv8߽k%\cʅDi yA#Zͬ^ $]ٟlh)xN0լF/8ZAa {C51ƍt#ӫfwhδgPA4Od#4#=GxMѤv+A#/վ='vX=#4Eyʡm̷kI\#4e)㉶v8vPJa{9#C6t;Ͽcpjz8%(cZtQ[anl^.V]P7[UWH̺V*>UUmUSq>?.Q󝵦^j` hQ0yyI5Qݭ\---oZB P躍jJ6.+ic#4/y|1#!I&^5y1U(gtc"7Վ~y3"z,`5a6/<xZQC#4C:җ|yNUp7e.ҽ8"ygɳ2ssˍAI1 #4xٴ|X9fypx!I5M5O"W_@?9L o#=[kaԃ0;]kCuO'׿oRM#/OZ=cSPuċ0UV-z(db䜖5 Nj%l GPn>@,d4G34F> hDϳ<_D4~w]~as7'N~lF^Mwsc3b$ 83M'^`7]HLNy\k𹨕tK%/m큱Բt ~=5xiupnFtlPE=sJ.utu|}_)ѓa 3=ZO5K#=`g$=B<^ ,f7*ƭC7cVV6+AT@9a^_hF e臊qnp6ٸ+AeLdtXAfq~F"Y\7gd$oRFzf P7s?]Z,~/M~Z_FӀ+H`c\KOvwKh#t* .[[]2Y-b.-S1S= S F.Fc+UʅʔlI/ۭFrԘ;0bƼ+A!}Pȁ3_0:pjgQLEf/Oq4g¾yo|#4/v=lv|ծL@u0#^q~ /5/rk+fQL#xo\K|Q?$ҽ# Ra0#s$AtpuO7>T28JYG *E)⥸eJ“]Z@RJ܂hy2CR>4M#=v\}9c6AnV#z1aq#ͶCNt9U7da^aG=0bdl#4i8!~GRJ'1X#=}W׈\R'sPm/b#t6%tϾ mڮڃ>763Z}7=6rj@HaLaRbTtiEr?0]c9aHNcFN{.`ڣI s2%Kp0 ! 󇃗%@O&r{ ݻ{'iss9Vh$E+gaD@=b[C&u˾4[=ߡ3=,J{t'7K|:j5 ?O9}۰4ƃݺߡ`?.v{\a%?[섺)_Ubmo@A#=JX/OJBO xσ_k9']]7"QvU9WN1y#!r0ެ 'RzZ<^XÜ#/к[ hN:tcEØ)(<@)Ga÷~x@Y=AwKm/oDH5P=rrU#/sl|T۹Q?P?\D;pOV/\ 1oK#ᚈxb0 C5T2еC{YW[6^d1x$@Rp75 #=/2bKMĊB? v.鯐nvy.navJ>Fava 99eusЂg=]ˊ}έ#=#=#v[4;P=9D-~878}ޤBT/瀂J&F$bR!!!#/_|_~IG Ô[oOC#=\9J3rFbr&1}I!:t#4?gi1 yJ۷ܽyyJl1deUAB종Ђ.AU^:wϜV#=#=HIFJ `0)S*0P x^F$l&CH]}Ll|KN%ir↚h0,[9#4S<;`6 ڟڋ}#4 t|VtxE#/.&M7H&#HA^b q\ ($Fɯg׬~3c۰kvXc?"dUBRR@/P[RFCЌ.}1^ˎ:m1[yNUO*#4u#4p'Or,\rK'nFIM[~%꘳\xF^Tu ? j{:oUi>:bz`1ù>c驤pѥl_#MOuZ*]bdqaSFZH[រM7#=Y#4N9avz&ծ$X_[v`tLv"o__R2*q54d?,tԹ\åvr708pvpMVPF0"#=y 6|Bb E#/B'ݥ q/r#)a)d]Tܿ{s0y"`Q=]:ƶa)Ȱ"i#/56&ݎB ΢J>Hi3jG@η蠽z&hFɉL|d4$$Xwz':t'wWz|@?K~c9.Xo=~fv.2u~#=|q20#Cqxϝ8\컠yp1Q+Pvyu4%zYFi}@РdIwz-)G&_)&lK'Kr]~Xoݬ!O(i<1 2VLB(f )ͧD'h!) 2/ٮX@vy=VHP\}ϑe`ACH.VBt+޺ֲ{>9G9~6WOdqG#,SQSx`$ڲfV3jmh`2Th'dD|D Yd\|LTC"o#4T`'-ӱ>l#4T1an##'lo,s<]zMnXX'̧'禪u;Q#=@,)ȡ-։GZJ|ux#/AKzS Ksp4J^-CE<󍎜S-ο5a_A802Ϻ5Ň:Szxv%-Fknh#/v>]d[YB3 Ң|d+M@_&!2 a[*SH;0Ķ1d˗JXX,wgՔQ#=^<|'ӧ+탠m7 E<ɝāmrI#/|+SYR]9@ZjNaB6U=&qve:}ְk:#=()SA?@ds DDS-) QW| WyCr)KTBA  }blh-P)haݣ&TH#4]86CՂAzaDEYD5ޘ !Kw:br"9k.`zڣQ+*5Z\";TD01(DE0ys76sR>BS͞%ZN_NnsƤ-3[bqu}W|7 )X%9"")Ȑe߯xsj=$41Ka,~De.ԋ3ՑșqηyqR#oNS7+DW3lh2#/RAE];XI<k HM#4X@ԧ`&$gy[ǭ4k|R:H!Q&QwFuD"t*`QȀ!y)̃BI֗j`0kmJ##/lP,(7L?5vMj˵88X`y3V \O1F^D߽Tri;7ձ^hFCbjby(e *,86â߉XMɂI(Z)%[O Qzzk&UH>;o@1)$3N"G/r MHASREMtH"=!&dfu]%-!!Y#48'D3^4Fm*)tδM['*G#=<#4Yvlhn!\^ɮ."I0~PWNMK4t!yF2:>#/ o0t3分9#4y]1`paNq.`Pz C#/a]Ǣ$6*ÈFħ&7sD10|<#p(eűӯѡ7Vu#4X[B1=V`!W~du2_@)z;:Gt:͏W0xWbPE)aFhrU^cKl/Ljd2k&{=A_J!PPֿ̕O ϙJ≗^4VE'8Yre#CAUQ%QC\tAjhj"Ƌ;?,pT[:qȂ#=㞷&m#/hUQZ?Ps;_a>\TQaPA/?_#4{)+#(.QI/ik/ot]ϏDB)}rW<TTg|4>σ%#=fH7AGt4؀{?#HyHFJϘ~8tx@?ҡӱ@XRd+ ޔCӖVt~x2n2f^k 0)sI*=.vR[#=$p0יC/<3&R+a~(=^Ee @׻h ^=vL=wL_"tt Ý˻5@#/̞Bi>jPXmZFC#/D% rcAݿ(Hn~lFD;7R>Zu+_rk#4:0͟yv鑾"u5o8\dOUY ќ\|'lg;Zhm>,6*D4cn6/m)@:)f7UF<9 .ձFfjO1.s8dcq77-̻Ba$LchKa2V4*!Ә&S"͗[=ޅ̪qB5=z`Dzc{JfA\gYϴqzc}0ȳZ<YTƐg #=JUy\,̻ _;wZi8eFUY#4WYL&[m%07(adFMC؍,Hd&cv񚋥7»8 ?ar[#=ͼ?EluD|f"ª*%L+Aψ /VbñZH%#)s:3؍jJn^XN- h~];<ؕg򸺽#=/C#=JwH$;zQ6 Ҹ07Ԗ:'V(HYۏYBI[v[ŚIŎ #/  z E0 *!GoĀOs"#5^ ?O:$y0?/o??_o/_?Of3?y_>7??_Oc/w#=Xʔw$KMk]46oo@3;j9?I&\9Zbl*QO'OC15x vi) \D d.x #48=Nt06rT(m~ĝĜlpHD#=WŕI:#0Q#4&EAp@(p1@!%ߘiVȋ4t~&?>h9:Pk~ |qܶ8'LAhCQgrA\hGDС;"0]S"hc?,<2|ooСFPc0lS&(Ի'w,γG>.fu{h>OsŗdZ-;& ~n#iP4h؏Jxgs2Pe=PQ; eV[:%&tw#4U0 köSi|/(?&~^Cȍ=<rWF% XHd =FEA8Sx"(JT3N唎{/<+R0dկv6:r H<#4xV&MQs@h|>{Hӥth+A"{,9#/EI풙 <7d& a~<< <z/CЛXIawiF߻)b Zt'H6)"+A!40 $#4LdGQղ|Qyr/A#/t&LX~ y#/@UN!#/Ņ {wɹ:H#9a_N=W_uİB"46jV3#=m" *T颠-H9uzkYFK< 9_rf!)>v!f{O-8)Mdi>E}#H+I_KFؔ`ZL:QULS4U/6f y·cgI#4!#4R`\Mi7diGh&(1?RaKܔXù}w][qF 8;$ UPEC#=L#/! ?jny8c̞8;8Bꎹ<<}]EgSLebhx_9s>^ܔTs=⊞0(i.Cm{o\uM1#=_ԭ0"z'PyyqV2y!,9]JR3ΪZ #4#4a.#/n$obܑ+Q86d!"`~o{]#4O/V?nq՝1虃D~A NOϓDL{:9U׏sؼ*@ٹt(%#/>};01%@[cݛG]eX=tQC `lچ"Y#\q)r-{'NJ[Β7#=%u{J4)F&|t;m"@9L3=9[BϡZEF=ei\8O,OG䙲nQfu-F1SA]r#DTAjbR6zW6< q:Ct0=Ԝ~E'lkc.ގ.-mVrעQa2ȭfs3:k6"Ct#=҅X4Uu$qBwnr$߰5_9JwOߏn.}oGCSmbERROf` h*ZCmǶb?vwrIGu=/0I_Ĺ3mLOGp#=딯)`sg鯫?'~[o#4ޫ“,%0 alJ): CfB7d>>q({vw)4݅Rug)%/XU=$C.BFG'pgRC<ѰggGM@吼aVDD|T#/ |a@~?iOP_Ϯ;y~ S/^ʍLIy8~07H @ԑOL=*}|@[+>ϰ΂I  $DڊB $@>ɮoW݃B$VoGqƙsEv6ms;4 `ƒ%#14Aa{$2@7ѬSb'NuU yE\`P fMDI걸tbX1q_XoO_iY~;@ m?q\y56ۂ""#4{#4|i*6S$!(no#4pG;áy>#/Vg<:yk/k#f?GWC`LQ1՘AIJ|#4?A>ޘpx"V*a#=,6s-G0Mqd u[ʗ`T0Lt*-_$#/fȔRNkU^VZ71v>UQE%"x.ޭ* }jyOН|8ST6z(FKkG/5 cSh8#/t@;kϥ)7$+JQd̠}#40+ۇB#/NR#=%U=6d龆J+Woev߿çޞaHʈ8}ZTRArG$0 |>}N?@#4%#/̈3yh$=APy@7#4F}_ DDP>ԅħ#G#=fqPKlsIu 9Q ~F}O}! '6{ELq?f<,uuu%A!]8]D/g3~p3pjnWlٯ˚Np%c*JmW DJ$o5ynORCjx# :ou0<1I_洺 ܯ@Q6#/GI(O#=AL7sD#/5}zC.gn|;g\_|t[B3먄?7ka[X myױ9S{.\>'@WrcJxڃ-&@)z#Κ(r *",S6uD*n.6~7ƓcxO/#4}d:~)?$/0Ï<}>/繧NRk;_&$ot陆I&^ߌFQe33z(\`0&SCffg)-)@M+qo1PHhCB;t>;w{*"__`5##4ZL#/Vgq߲"XJN!c!!($+$#4MOΉDDHo0Mnmw6;.Mڈ}a#=##/!JXM';P$nv`81{""2uRO}_FИ8%?6{&33mxu$q+9qRͿJo@k7[[h;#4&p#=#/2P(Ax~'_Mofã% 𼣔{=w?5b#/$R~@.FBQ(F#/DyI)۪} rG^q_6B@HR3"F<ɼع܃)8@CwY[.IkQ?Aj"Nv 5]"OG/s|_钩<{ϰ!ȈA/aepQ}Q`#/T}(~X ذU|,Ӛ*?D=ʨ 7=C!5=M]s2xN눚5/UY6ʤP49>RGC$[YjE[CYqo5a /Lx0[W#=PVI jRm a}m=:\ss83X󚪣KBp#u`t#=-NCx-T%Axtx^.ۧU{u"5E;G [-0ՇOFCg1ö}U]Mݼb+e2"i/MITG9mko&C?weP8[T}8d9C|J"1/]$k}r}~kܾ*ˑm9G#=|eS"LLo$Pb8Ln PQFP%?/mzõj\bFtzDZ"k[fiVj Wzy"[<彃^3o{j:WW+;٬ V{Okh+t˙F+HfoCaËESe8nduT/F%#ug3u8 .UyL:,%nvָc:bfU=t__>cyqAN?bPҺs߱`L| 298u~LNQpǻ%Ľ:ꊜ"l8fn]Uct]c6h<‰MQR {C_p6 7&:EM8)#=#=%#=&X3"6ܓ>[Ɍ*vԽn{wf0?f/wd`Ds(6Az"a{}M#4|!V0!%جP>8 <ﺁ?WyMb9n'Ps~}3*;\f7!+ GZ!E9Q|K~\6?Q='?5$)Dzk\>+ӂ.Q3ư^Ơ#>؎]q}1yaA1;{{Xx8uB[JsRcӘ<+b1um zj)fvX ׄ&c?b4[੧w)Ϝ:?5h,⠕I⨒bAlGH.˯m(bm߻8J7:[WK&ORR ɇ1&9(#C?P{n9B^<2h!tg#+KpB^W.nxl"$c-`GrQFW w3#^FEH#=Fք$D 4wPKpϷuSC)ԪU*&"/>IP߳øu#=^#FK`׾s;6;r#ȇl8Qp(YxB05PEɼ)EYG lJ[3EV#=4veR].Y6?NdzANQ3_&nZ-FSv͆>Sl4UJ:3 D@=;p{z- dq#/з)G}ᛩŀ~;]3 *3R!f+:Li0sǜ6(A,`M:qCi:| ¸:q @0.Ly*؁|"'g5EY^#[3L=ABsW+񃐷%J.2 y냅(xjd P4c9U :9Z"#/M. GT*$JaC:CzԥHxǗdH,##/B.#=I3c꽻w67_־d؛7tL}~fad'1:Vxaєb%~La0ⰊlyZs~)洃:˂FO-xpsM/H|<)z_Q爍:dol!D.#/n $K;Y.G{?.KٞE#=Ό8phIxdS `ݧk!Z:!>D=/@c<3>=3NwJ}x{dU8G$gI/J#4lXrvF2d[CCѲeI $Om#4vמVwмPsa@J#`FcVrhMO4Ϣg@_+A'vW~.A7C) nC#4KUUNTdJMT#/#/)%V:!5 xrP=j}_&[O~|nW64s|T{x~SR|iv?z>>OKKeBʽkU E3j>q.D K " e@$>,$'"$͵W=^6h0N#4e,X{0dd-'QWSo`>)Pnu*Օ; #=R%>xV4u~tn|v>X׻btDП14(%@#4t?Y'zpr_zL3΍KeTB_ ?1ň!UOIDQ#=3 $_(9݃"CҌNIq[hZ5Q#8Mkf0;N=i|$lQG\u@a(UH1AF.F6ke }hDE"aL ՚3͓4TهVCeT!XpCLf Z9y/6>OD1À03 }Xbm1: %#աōe{&ؒRhSR; ,ZY;H0#4/&NB2C^;g ? |<=*>=gDEFNѬoT b!,r,rrW%4Nt? ?qrtȀ,Bgnd?oAX~OYm4X$?"kH4=|K?@3y^o3ē}}11,tfuI|>\b/:3 -5kd`v%);c.g[%Jtr"482m)愉ĺX(-j+N\`R &O͢Ł6,#W]#4Rڏ*=4vi=|sr@2&#GNgrH)g@j$ 4(7 dĠPS$\2Kk6k dr|>W\#GIgDߋ,NM?[i;H6S3C% *.{Y Wi"X(7HL3`IF(p(F1#/'}mp`O#G6P6d1x4N76vz%֛5GoΩ?Yeqt?jd0_88#4 C]JE1$+("8uNوfBwjwšAT5#4!#/1rwE7 YsVo#/zix#/cˋq P6ٯq#4`aǗ]!;.X@*#48ڵyɠCchADL_gS<#=~\2AC*Ҫ4t:cxyI($]+d۵ArI ns݈av@Э21|dOߐ#/6@9#Jrv4}y/Go(m(c?i#//a1_Mc>ؕMOp5>!nhNF_^ׂ&8Y2̛twӾCg ^ _k}o#4ϩ䞥hSTN>#ɛ=Ҽ.#4ݐfxG34!#/DȑX(<1Ӑ]{|@6m0%&<5+G< xkv >bB|P^"Pz ] @MUuD) ;9q̦&B *6S\L['0ѭO0xiSN8SDdVO#QZAD%4A~xulwP/>Q|*Nc g#=G 5b~54̑}G6)s¾Eg#43r{6 |t|BOﶾ:As$Z\u8IFknoWwz#4B~+;ukBĝ=B0quxЭ힄N0*+INUt4R>*@ ܫL(+$x`~U(xC=zە;3_6!0x90ف{4Hv̗~5LEf ևІQsQM%(PmP:{A{qL6P >CC:/꤫h;#=FBN# LFeP]<!Z0xw)8scҋ?  li`Zbgc8 vl'%F##/>-`#=ꔈ$)?/4| U,%`|P)Q=6lgFP!#/>Fx5 ɖZ!RʶuAwD/ ߟ{:bO?6J%#=b.i%#=<ժkGld}'Pd=zsmB{^hɃC1V#=(9q__5 tnCe,,,x)Bb7N71~J!6xEik:henhDI3U?5`~'ndYS?3'٢_E3{Wi]13VteaFR>O 5a}}LR=um? ~!A D1YMPsM> 8'>nͳqۆ#@8ԥúpu$6#wQ"q^bjAi/Hq 58& -6!QH{eR¤ߟ4i]C< fEG殀_Xn0!hR}.lGo*~#/{gL b j Q 0o_эbHQ,?xe-8uf̑~ls8(E!Kl4?vbUѯT:r?72g#=usB"my|.>)>J+#/?_(sqF8L_ױ!Sy`mC`!k:ŕl #=6q;t#4G5=tCN@#4;4,B M td_HACDm-^D"l :Fo'J{:<@=H@$HC)g[%d "(utQt@I_қPDD#4[ƣ1{Æ>Q|k.#4Qdw1KM5ր>{b\zBIH`!~9?/Ad>; 7yӯHN? y}U:攕$$Io;7ǻuovNni=X*!(@&_j{LoP)|:0=z$`´w;N67ڹ׮*F5 _xs8fw{CGTynE9F/S*_^]C~'^bYb&)vt#4:#/"^,ݷ 9?VƁCbw70y8䮉p:;GoM?;MTCD߷?L3#/DDUOD}+0=#/|" ԁ T@Xf?Y\[-QFW$m55[ؗmv &j"~t,7N |ّO\^ͱtH?X-U4T}*~0 I}_>'Oo Uzq|)\QO'Nb/ވ:X#4)!֧f%.jMp؂-9lt컚]f52ZЙ'8wyA#΢,0"D1真aUqK4^PQwOrn?QT't@r#=6ɧ:u;qn]Gѭ{ީV&":.-UC[0?PV##/$}#=7 ]?wr;2" " TJ g=Yz#%Rt\m<@#=:t=cǗdw}#4|[P$PACWbxY\t+PCS'fE*67FV[4{|<pCdBOG.(:u1&r|9#/#=MR }[r>FA>k^ӖBju5݂^til)0~OAc#/4Dniꒅi ̺ m70=!l'bJԢ/wOi#7Oc @ru@#/ ~g(#=$+\m&ZN?{n`=_b!g1#/c;>>CF|C0QFGnrv{<WBk׏y7P:F]ľgh!#A,[Åryy"A#/P/R렯^S4&pġ#=#="z_5,СWQ@S܉Dw/P,#1ff&s1Ul\]K?,lOϷ/=KCIMW}xw>2ġe#4 ޤw;x-4UZM'H)1f-#=.^p ?!6L 0>w@@uMZ !V%`/h &%Dٮw Py0Z\\'98`dמ@DKyenٙ_?pow0R:}ڊxDTA0QGUPyCsg4A#=J Fl!-ldߪ^i%SpM!d9Ɂ(*NI\#4upbH @{.R~OWRWM<}|0A[@SM}>~\đuHA1ڍ!moV$)zP(U*$ATI,Zc@X}2~F1??ߙ*)r~!o`V#/&nȀ,3;u>Su|R#=Гf2]=;080^Jf3#4ש)igg]QΤXU PIs=+@:$|S1F8=٤1Y֡(H"fCILlNTChY:.N|4^Hn.U _yá@\utx7;D^N7RnXZ``@#vn ビS؀WI&ݥ zY6q0uݞsP?F/ q< A1CN#|_30U]4Ƿ: mYl)d?aHr@7.#4q1_h4 Gɳ>eX#/ȩ`9:C=S&VdX{rI&m?#4e5TUY2KdX*3F¦*ldqק $cAIb02x,07?G<ߧ~Өyt ͞gY1eQsa`1^|O9#4NHM#921O>pQus˚={YDۇJ?Wd9~B>A͢#4d[(ϏI 1Orr؟#4G倃܇R2i K94wƵ.ҌбI#4]F!mol*WACNv?~Kp1ﺜNʀ&$O?n"o@!Á5Z3EOS~K=5]kuq*U6#4660p ޡ0G=^'>Ss+c5Q?gæCQ|fN-(lM$}Dda&;u?⸔SĜ a]q+`efB*K#=L ' IW#/F/^Sſ?n N*hI |5 p@ gq0A1ab6| Kxz;c?=ޏaޏBU>ܬi ÏuTGdv![PRNUq:d!G0C=#4VޒZ:4e9~3*uYI=C2jT$ #=Qi>n{_DȠ̜mGb)q8I߯tD,Z!=4#/v#4ond#=$$H{'$^z.O#;WES#/@M54xaq:W؋6cy۲#4q(@(07[!5^<'#/#4HҟI~E<0|#/o}UW)oq$}l`#4QdQ.lLM=7Bێw~Fx?f٤:~̓ٙ2Q?WHPq#/ ׯ:ŖlI|͓7ݴ"c0bf5x =5#4&E,%; !=Hq8M!~Tj{USҥC嵂18Ϟtw8ˍP2dP[d,v8vIpL3fhŘYߜ<-?RugS[7Ts߭o~`Vãޠ3jzYx$ Zf\>_,'Ibblt2(qOɲ:ï@D4@#=J^&~3zkuւ?$M!2LPi_N#/Yw#/Lj*'ر8/zW>'Hn(1%$1<^)<\LdNu x,0cia+-!\%Dtor#>N6y6: }p?0 #/5EPj]ǻw$B%IH-O>U+)G1G,H֒FvB#4 kM=Bdp*BI1$ŲGf7E#TAO:ӿԌ\aqIcJsn$)9r"j"Nmfhz0˕d+ 26ŮۼF9PnZڡZ Aqe, JQx`X?[JԩTK?M~qhWlzfEDꋬ#/Ig40U?~odb"!Ej(#=H6#4#71OEk V?#/_?6(Cbb1_T>XM>5I~ǿ#=k3_i$lT({Ow|qGn% ]W!I>Vu@n3_ˢJLPG̅NY@k ԅ|oϴzÿɨldUFtpR"?%P#4Q~@2H}bPҨ!O218djV0, Ԡ2#/. B] 0+g$R#/Er K<}( @HD4><=ԺIqdXUI'|?py{`y&ap{#4@j?H(b=OA@r%7yA:#=/%M4'' D_S/q41BfIk+lR*xMH9S 4-pcb?fhg9BR(Zo#>39NS6p@v#OVva^f]7b?V"fi#/!`0B~~˷ֻbKxudUQ@+ۣ~sTu9Ĭ%(#4J;?5TTD5ZZ[2dA?.GdG+e\rQ$eP %%EqpD(#(^~:DK䰛#=Dre(/A%Y6Ogn,ҋoF 1Lr󁬩y1#46oRaTv-b@!B#0LS_}@(I|`B#uO3|cX=W7J<}HoOœ8L(o#4V{uE9'e.j$txm=ïJK]qg:zX GPû80)HŅ#/c" yHab0X˔jU'cԯ,CJJxC26|wQ9A FX.y35Εed$ыsn\/Ч5o4C(Y!XyP"K'.J*"@t!$@4V0D#/B"fO鷞oh/U; !ؒZox# Iz(QHnY#/qoBwh$f$-Tk/5 u@މNEioI퍗~ޜE&#/(UT,|amQװie"#4Ȯ4EXd-B} 8d#=&s<ƎsdbTP.*#N#=u #4qsl˯rsJһ-Xoa:7Ѡޖ-(Fx{kjm>?nφLwtFażp{S`4.K1LtaJ~}GCvgrՑg~wQEttP8c)K{k4 D[B?zNB|=Sh 9ܢ;, T'Ef z5nS02#4H*"FǎPs*/? #/Pa[Q4ԓy7cǝHu^ a_1޹zY8鱎I~\˽"T. /Y.p:ЃJ׬k\/,_?ĞBHzpM#=FZ1gKNɯ+5xUh2GAP^DSzT Peߤ$F >h!%ɐz'}́>9sz`2f#hRdu?bӿ/* Oe\jT$#/8>m3 뤼EZ(\v\#/ bNgs$@3$ s=Pc8V≖IbɹpD#=wmD@ԅKNj d=xod &~534A@"n4V&Hs%TH<=L9!2G:%FŊuLm렜=&>XNJfO3?^#4,=VQ`Y()C|A.)03=w>a'.EШR$1ߧ;wr>XeC~|G36;N_}`CϪ$j_V?O\& 3'>!GgFg2r7nۭ㇎"d3,@W?+=ذ:z['c4w1$: $el%@x(/M#/E2S#=I$AH+rA;*kC 0Q`b52^H`)U#UKMOϦ1\(&f_nz?lzOݖGbޗ@G!̴ppiu͌p#>oBS11a##45G7u^}bAC`d?70w7G1X͖2!:^MnY>io m`$S!oF*!#=wmt?=j-r/]TEUUi f d8dݹMVw l2"DGwS< ʤ1hH47)ِOɊ I%jcFntVHbhX^y[{=zm7:x#=q?N,d`97O"p8p>| U L/AW az#=]X<\>cÒ`_';t%Oa .a/^l|Nf"d m5!#/w'J(0zaDoƇBa5\Ƕ<&0y*(I bL7m fs\񙗗=;3rmKnk^d ewzg-d?,8.0"8Ɇ#4(ۅY$6Ί&RjօIuXb#4*֬eU9KЇ646IC]}۲=k8a(%؄cWs(0@`N%r&CzMNq7fSZΒm>s B/C>X5XK>[XD@mTtR*.#=QyT(j"$gQi&O/~9V.qfBtM(\x:w>!#4ޣ5<CW hA 2)ݑ4wTJlPjn/WI䓡;0B"<.{jJ2%Zg*|-.,nPV5#ִ<΢}E|ɡbc7 #=}&d,i'C T9-#=kAf\4)4z6Ȣu \yhg&?,s,i#4||8/H=^ޔcw~g?o"~պhd1/oG[cQfm  c:`6 r*A#4W+R˹T9M {_O0'҅+E%RT}b59.HyiLvΆ2L^1i5E=#='97:b(UPHEAJEDV;hZأg)9h':98 zk0uIے̲g!'-aZVZ#4- 1F2o;xwnG9x+zEL$njuSų wW2xs7W :gttB̰KhdE8:ZJ$B338cSX).}ɁxlYoD$ٹsUek0oNx_}e+R5X#f"{|J=a<ꡨ^Ryh)ADw6q$Bux"4stzNPuM#=b˃M Y6Aֽ2I.r`yTb0i8ɂ&]ῳ{ T p6-G u R dg/q_>-*Nrˆ$VbG~{ĪsuÈCT廿<ɀe8<8̌ߏMm*Hh&#4zaiz3<+#=&CD^L[<2,`4"Q(M' N#/Աɓ#ƪ{#3޴U6'@*QFa :qۧS;0Ne3@9Bϯ83Pj[MIbk ̘;ٚfn{Fjb#4ƙc#45"0y%$d/R4ʛA봙 b)ZZjd3ޜl@#4j#ޏǞƈ~/1oGg `j0#0r'{h#xqϳ+#4ˬd.v{O˖B䛧OP8>F(f~׆#4e‡~1.8_ s)_g%!oH(#4akc5#>bƀ$I"LCux]>8reD8uFB'k jNЈiu4!yzR'X 'Cjr3T#50Cu Cgx3q8ԾN2U=G9Ciw@hWN YNrzRKX0;C#/8dGqE*4&J=I8Q[3%gϪ2c/X;В֒HLX{b*wwb1wۺ i $S$6X@.t5^iL0$ueY$إٙ6NP,apȳϯo{a祗MFu,~V^pp>e׮V1y!h\q5/^1LQ̎,S C;_7=mt1wNCtgmix=Nu3r~˕Jq)egQN8R>Q)A.$KaSKXG"Wd'imdǭ`r(!5/@)i#/,'4CoUt7 ,\{0!Z:qkլ!n{)#=N\$٧>$קev-gC|"}CAHc4D @7U#8{j+z&@}XIKщʹF@Y [qXxT?A>WH]ޖ*uRf.j#/~=ۧfr@{.l!#/W׈p=4kߌ̃ubs,~^zO/ǿ?2`U'=B'6C澽ʹ?-O3ʾ(Lsp =Z|g>gϩM:Kws/puwG@0` ۹Wgr*|kS~UЪ#=OT(#=d#= j=bmRz=녌(ˑm#=T1Ʉb#=4J$xEnY( xlxa)'L&SD)**TcAhJl3`[#='~";U`aYDޚU ~ch)Y. A'#=Dhx"?q!T* \!0Gc2,UFD?B^>χh!۫cܕ:b 1h.!9S0MC&TIM#/0L(eh2 *z:<_ Gc]7?23bjt(**|p#/P+z /r""٭j6E (s[uуG_GxCI]"h_Sr*Xv}?GT@@RLLQRR{dL#/@9sUS=,#5[q]ebz~ڃ0a]gt#4 !B2FPϦZulh+HDH&4_uλnD2f`JQlJu' |??'iN0(c1>q4\s6? gʛiL//# Σ(#/hrP& |J> @# /+2;D1%#/H! BGw@_h@T{9'q)5ޤ0X#4@ ؽv15md]73@$KуfE2qͤC#k n(I"+B1JvX678o$kB#A΂!dc0`?`@4c&!` z׫=]ОCNE>g[i>ed)UNqF*~dIJ֜DX'!e)aA~F&dC?G'fnC 1)Hmַ ߸lmjT$VLflŹ}(٭sv_gf*ᖚ&[tHj(7jnޟ*+#DDۏP#/U`uG=^GP0#/4 A()F2!&X~ߤ#4>Ln(#=kb+AƊ*${LQ!* #D@ 4- a(ȄP‹$J??ZI%Bg٘O,ՀϨTF71%0#S J}\|#4& ǯѦ'ZdE8 6tDTRƺ#4٤fӢދ4D@HLb 3P\dBD"'C`.<4h2ZBZjE Hᒔ)ih:#4$@ 3D#=I"hm#/HaPЏ!)C2v#=R1 ^L7,C`@ \GNoj*J;tC}Au'#=Bv/)x *ޤ~N+~J9zn)fD?V$>o^V vF+\C L*(_k#= 4ۖ&I5IԚ#=|A~v%#{^8#/<> mt[u<#gMu#=T"chDb#=T(yjEc$i4sOn=#/#4!QZi#SssV@dKr XA@SV9%\Y9 ==@}'g2"VJ.gh}A+ZZT0P困̎c-n3&#Xpl~PKԸ`fzn̘b6~ Qa眫GYeL^=(匝^#Ohą0#/~SoB6W8u&׺JH?6v@knAbJICon)>QCe *CdǷ#4LUnd>D4z`4$L I*EH&1{UZ*#4OST^}?E*RaQbI/>5Zק8pi\5l|#n԰;\9.9Mq%V~H\B;1}#/he~{(2JF+0s#6 t.M#4#= jIs^@wVm^HP`(UZ &"KϨ`ҫRpm)e[0_I?C]`,Z69NAOgp2rlMj,lm*U"&8^#=] V*r"@0k:ԱQb,lmb ;h,6 "-L0Ȫ4?Nܸ'9 #42S"PE4B#4 P1%!BA-%L0HBUE2B!2@2D%JĤD% 4)P B@PJ¡(P M KABP 2P'g~=+f<$IiK*eNwK#4]-a>E*UJ#/iQTiQ#/C'+#/;#=s\ >O擡4&`m?^6tO8|3`niBHMhyD@q}N;AB\` X(i4PD90lg >x>'> XTO!z!#/<G7JD&C@p~BpiMS~,BAB~nIÅ9| MRcwNF?CDcsftw'6g1]vp Ŷȗǂ!c3P`9`,#4`"$sOr~nXlŷG1869 JL`)Sz";ZhWoM#=?٩=\تsJ=(rQZ#4xv|zXՆ~}Kh)ԯwkR6uLhw*<3?3#4f,giS\8*!4E?daJji/ ]^0>0'l'q=2o(FM0^(!<Ϳfu&#k`#48XG='PM Pbt} ܍\>ǿJ= @6#KA/1+#4i6ĄUxq h9uѨُ#4D!>tLAӗf:afAAa'ivurc9|©YU1"n (GTW)i¸:CATUXÓЁ dd)Q@[2QZI]-_:*;&*UjwďM={O#=ccXΌMǑtLjW'PsX"t#!PΛ1hzarR%t7΁ M/g}QEDŽABLAKBPQ")=A"iՆIA& 'U4Du9)C0Hn=xѿӬd{AdnxDX49@xuMQQ LT#]lQ3_Q{* _p@HA~ey*jgClPezPm7}ܲ=vĂ|h:4b?UGQsz蹧DV064֠c#TNW e#=,'@`#4BJ"*E%Ե00XN#/i:ABh:,HR!ShlTE2lh@bSE.BJ D:}rc;oVP!6#4s6R".kx-#=A Yg9)wbQ-ٳʇD/FGci+FGg;Ʊ}/m]'џr9k>FHcјתA)/{1xp|8Zx#=aK#/W-_(zD-+m"4A6:X77t`p]\P) i(c;βwlОAٛ*M80hs8~gB0.jZoK.J dDNaHEa$;#={uq\k3x<cS<9u1|&!kzI?lܛFbey֧쬇RmeΣN/{/w!ôudw,8%iQbnwX.hWmD#/iA/7@םH$N#=^@jk_#/HGxڑ@jBfn.3tAsJQ p #/p;T3~FT:c|G-R`}(C~K, <.'&zcLlOu?#4 M aD`I]p%#/y`/jU4@D{llEWcvtef;T-[ic9d#4 HK!իY+LѣdChCq:I [L.=P'6]DvuA7pA4ԇ]$/(,\ˠ zKü}TO#/3Jk_qٵ7sn72m5sfR9Hf!њ"1w(1+yB0w G0&h*@i* i)*eS ɪ4C@6/63m#4MA{:y$h8h#48z3Ӌ.\%$*ɇA >07N뼂2!2= |EGتLiօ)h&#=&B%%S++Fҏ_tKCm2t#4=SáHI8mnqEG#=x ӘYQcV*-*¶O5)I{EǙ\rKPU G`5]86;`Pd"{#=#~r?>;y'Ӛ!Jtd02vI ޒ,*@n}H^ i&lm(xo 娪"oNM"TŊ#=:!˥]#/Ҋ Z7&];a@c+@8##/w~@QI}0|=Cv>{8|H#/PmE!}#/|M=6p0Bpt#4h-E#pLpN2sF7 M qG$!e8(&?#45˅_Eh%#\$(RWl#4 ճcbCD)#=((a\Kv\%!!̇8(1F#4Zq h8x8 qO@"Bm)fR{ s߫<몘Pc5ɶI}a*&tNYOAE*]͏̓BX4d#Yox\51'䤂 D#/;N8~7a։B)W-Hu' )l* “5ǹ!3q0]g*Hn;F:dʼnD]"bz/Bz̛a rc<#R@zt:݆u"H+Y4tjg7\#==C}iaЉ>E1]ljl&sb?MmM2bA ڪ;Nf\DrK!?F\y5#=Ȅ&OCTp+4P!Eml=6i-DMbD5 @d@MP l`n mЩCY>F${UhC5%tGPpČ$^+NTe;9Ds_qwhȐi v^eBiaS~:q[J<4L 0AK`9HIh,J_Hc=9A(UApn=3|_'׳rZLGVnz.brx,b,^WHH"" `4T,#4|04V Pa?;SKo#4ږ'NTNw6xr#4aPդ@@<+fu 5ahå570M:: bGUrR%^ٺ/#4#GrET!#=Iݓc j ө߁u; 5-$:D?K :.TBW`Hv[k<9*jk:+\gAm=E<z> >nQP~,' ?JJzk[u:M "a($GD \T!E硧_pF 4%3hU#|babsCʌ|/t'd#/ AWOoa{ HkP* "iA狋:xx$p~EԤ'SG"aʦ0Oj.HYx"$֥#PVF'kpG;%)`N@!I!4QCBh(҅#eb &V9df$id3ESJ=0vbI" )D@"#/2DQU7 1#=#==e@TcHRS#4pnICM̀PP8'3B w#«8GT"%q3q 1hLPbduD3#='T!ީ#4܃]1&vTIt#}1Ը)N5~#4!f>@pwD\źABJfPAψf`5~_aɄTJO,980T1~ LbL}ten^[5o& m@r}[%C0(cTc8cgh5 wktүʊ#4 (V%V4\eNYWJ 'zɗ&xrT߀%f'aGMG\3d%hNXym;ݞC*Y-}ܶe$uzqDkV6My(OA&?#4#=[QF[=1Ks֡/͟ީa8Qj"#5I¿ͱ(EsD5FGP!Î28u) 1ܚf#4&j-=Q+:5#493JAsZ5A8T#=$#=6UAɉ^c촣C[ozXע巫חyz4t3WH1]4d "ik IN7Iwwrׄ]}RV5܌2 orVc1WZ8d-(ԳD#=He"y@s8d,zi3n5LK(h2!@L3Tѭ,୉7G!>Nyj'U(LnҖ: ,4Օ-=piȹDž9pqګ|ES @4rtN\9Hq^4D5.XmC6 Q3,:1tj62EҌcr#=v15ʹ`!;Dr=Hy+Дb}l'Čg#JJ o'n ׾a̩#46ozXXFB1Q0"4ޛ8 LO+fGu_ko#40*]&Ӭ:A~#4]aL[!fsS; ^9/yPL==3g,-ۮDeέ _#/VtB!@x8&#= m֊ dCgHH y\ rb9. |Q5/&<=#=R'V,#/l5aY̽ Э2(1)jѰi lQ#4 )YSyH;SZΆVNDKbI;51:.@zHM],Ȑ2  єuaM$ͬ럏ׇDaW]jg#]1dɑc;=8s5!HTN_ZW|'C_BGuu#4 z҄|8\##4, ( "#}5Q,1$HME@ J'و[0#=TЎ@2 Ay#4#=5Tb)"l;+AwN2\1&'LIg݋ݭàϕ(*݀wlY~>h$bRƒ{3żƭ#4nj&sm5vM 2j~K?ozZhō>(b? ?ʄXjҥse3ԧqF?mnE!N،MHaCgn_"QZu=FO~>DpAgz1xCL^#skFEm'Ӌ#4G 'sE\7Oo73Ozo^Ƅg*pz#4]ݗl+L(#4KHc٣74c)={%{Bb^#=e =9ܚ8u~{c#ƊH_WJOfj(rK8 Zq_lEZ#=&OR<"֠}{i<,r~sSJ'Ҽ;oFX^!i\|!c ˈ|U%ͲƏڅL,֧6ƍtI8LsTa1+tg7R #=њz*)腮X\ZPgZBC]jͮ;QDW0έb:]DKl嫀X>3$9[tŏ##/2hځxDFF~ϼ Z)À]fBoСP8(vڃ6~9>˺S'Q-ӲM2#/$Nid,LU#=beg#/ra=xpx#/,\-SۆѡH!^U/TB#/B8!}(:`Ԧ2/!c)Ot~_ўuEz i2U׆~mҘ pXV={ !ho,hYe#/z<{:B}h&{VfX`; xG#=Qm뒕&dWï{eU<f- p2Y6LzeF4;Y0P:(=^C&Nt*zyJ#_ڨBUVR #4AQp l/Y{:Úvܒ't$iҺV$iRk׼#/D%)>wUuZ?sQ/><!hq:WUdqX(rY霒:NYŨ$Ji#qau`bxc1\̽C†i>1CeP`pk[9*_8tKJy\M[=X|xIH\Z"j^Y:j&Hjl;<l'/!m:i8E+Kg| Z0['7Λ?z1=ۓz]n5:R<}Q*]zTn#=b="#=n-Y[CB:L:aD_gɧJ#,J)M뇺y~iTfw̛t(w\SXʗ\EZOٙEy ]p;j4s3o71nkVlWw,]Nk7#4"Xt/RY|<#4B'QU❁9ImK(v)ÿ3+$vV(X3 PBitbV96y:# Z!$UKoyP}3zMDv#4ܧƬ=(|l(Dǣu"8B3gn]I0= qla#=`pɍ0mL<]=,PZErl_8:v5h(5hn_[1)iˆ+$|,I`sc8-AqT5jɊwV"Anvo?7 d̸&0&P]\a#3Ah&rM萩;O Pid#+``İJܻ=˛1 v|Ze61;,Mc~8B3&2{E]yQ^zFf蒋¶*mvèC#=Lr=5wQ?ND;Yuy)ʕN>6`?{UvW9' ug{߶;REm$XR LkF\h1GmW{$Cdꣅ`.D6`M{~o"]ymc9205͚IKv!O}LC>"':n](t %,pxu/D9s/na8]c N;$>٦e}&R%Eْ0֒3#4z [B[%cPò[#=ߍ=2- I\(@UoVm*a('JYmb U F#=cf#4 -|BȐaxb*ɇlfˑHa&Ĩ8"X>×Z0nR9GS*m_V\TNRUr[o#=k+1XVS[ڌbGdr5\c<%IbﷻJ]o6cT7Hfh1zB)H^#=; ]AGMMl?\n +]LJD8puψ4.ÒšMz)-ݔd6s#/L$J3\]qR^RרiZׄv&=,]a&`i,5{t+Olv4A"$6baH#NhE&!UP!M=:$לԤmDun@81#=ƇmeON!\LbLɜY Đ>XC𣟤 Q{52HM&]2qYaJq5mnAFj+F{e9=uܙ5/#4\Fh"/VKҔe(OXqN:[p֦#G}e]WDf`'e.͎fSeQTJY2g.V5_+7I vwfgmq;ls5cc.S534\VVc1c7 ^29HtsXv &*c'Yq#Q"ʌa''B|HɌnu$BV3>Z]*31롪t™֎mnMd"P`F嶶\"\\?f Et0PQ$ͩXsni`W^$" M$jjMKH-JʇԻR ͸;lc)>gc'Nݲϣ?nIP YeK2zեD-Ќq'ʣO58 -K_1o*:޷~Wy/m%/Y; @B:fyd+be-#=f9Māw!"%@8>WFnm[t)ugHp`Kv̪,2j41Nnᐴ6ܭCJ:5(w#8aY{J 9]P*=8veLo h#G L%7zwA0yG~EϏٛć 'Q #4֡HO3em s`[%8ɇ]] ,#4Y92(Z&hc4Xۥ#=֤Cxc#/0#4[224ڈ[ xfx.BJ#4I{L0plФ*Z#=JQWJiQiGzP5dGrf2.BtPmmه?Re];ø5fI@К5!Yxα5@{-$89CR4Ӎq.C\8`аj:m#42#4Gh,#4'Xc+}OqxfNGbg*Bv9#/t#thA,ȪF=O:uhY~/h=iSzw1Oq-.I9dPj*Vxz2k#DZM$36Rr:}7#=c@y#=+4Q0`IShj(jpn'6b8(2K ƬDf5䁲?.CP#/Ԉ@pi6aB-j#4C`2:#=Cd3˒T(Vďgc'rIdz/RvHdH₝#2#4N+#DXDJ )ؒL9hT`"pE53J&I,!=ʼHKɆBL01L53#4arXa̘3I,ٮVp2r75 FYU#81 \%ʦ $r,`:m SrN jz=㐩f֮iw7yXpĂ3TNc W#݌K#/D4@T̂R0&D LpfP6[1^K#==C3#4p=@R@CÚʰ): LN>ʝ$#/MS¼{>#/P1 Hԝ CE11(Pwg>*O#f"IQ냺S)ζևn)mӦhRSܔ~t~9Bm8bbƌaX- iN#4 ^9!;~#4Xd##/Au݂#/D#4M/Mgo~$= .(^>N=POimwq,&[r<[T#= n;P͓/(y;+(ZGCwQ"fTˆ;^P,9k)w4bT3 f`B]Ï75C!mr$?ztΗfrJ*<ɒA{ƢY8t]39M7A'%q!Zvck/],k{;SR%62bZ|ÐaӜ6^|5,2a3}12</YIӞ׬.!!eN)Flκjtp3sBL*,;y%v2}cy>ӃHx\PKn/2ն֣dΩPkzyUv{9]Ft<]P#4Wu]{谡\){y%%(I 4&6we:; &{(R!_^Jżx~7w:s' ]b58mkزg:C-.A9CK޻|I6D*7NӋsE (}ԤO#KVϡ(ZcLXs|9zsQ" +>dl+jM:y"6-յ"Mk.\fCڶa𹶂 nm Ruˑgk aU"9]{5d=L0\c8UG==$@M^B+*X]Dne@yU: vrB5cC>e&%Ihv9eYvH6*Hgœ` lw[1 HAq*(n:GXDm2=6S=xZ::1S1C3ѕtH gQ}@cH]#/7v*#/R'*#/CuC#Ƭ`)`4l:ZAA@{vُ8bPb#Rc4׭#4$CT478;Es˾M#4Tke{k^2h\2#4zL(QA#H7@V8fib6d"]Y#4@rP\)AaPACF*RG,}gw0D_Phͧ5GhLHVCPq8q~Ћx]aO#=#=A(hs#/T:1#/Y(<@}*<'Px#=tiI$v~=}-S&w93~0zX??BR/պL|v:lYNB]hT긷'F٥0:ރ¤њ⣌+ a3Dy]&|\e;Xglg#d <Ď+@f9'ygNTuV#=-P']QpEi4n،-;#4~\s2 Nbi0*kFCFf7ܨkGYi#=d#4R![h snf1aBpmtڭ%'S.Z*0\%H"úK}u3fE^~/}d 8Car[(;  "3wW~vD0nRdGn/BҨLy `ScmC<E* TLiH#tY#= a6n(V@..X:C#Iu#=bH0Rh1#4I]0Fv!b '}aHb^8cxYq<2b1G:QV1ʊ"4%nENHc}\qa暔>3<a2-q7:YGhg:d_PYxv㼷\r_N0ds0jCˈ#My]7g>RiмQ\=Q 8A`N͡>H5e[KdӘMQv2`=m,!4s/0ط*.u孓#=w"QT#n jrK18SNP95ur1D߼=`k?'B1P3#ݩШB&ñH:7$Oʠ>QC;^Z;\(҉0 0#/xʯ$R PI:`0Xgࣄ*h^d1sa(ly7ۼN#4<-)pt#= ÐcIA#/}\1ՂFkA>#4zsbrI0hm#hh{WyFnS2$@GBzˮٔ 2C5If1GSl#&tŖ4ꩂAJSC :%DQN+ptOy*b#/vJ#/)l qCW0O6]?Q/t??޸^0#/2QIKQDDEJH5LB#0 C.F2? Td|GQ2,J`j+3"?8OIz -0[RC#/8~h qي!na#4QC8xA?fw̬V8t/Ru1)#4pd}צ5T>[?5x>akZAYC#= s#/hKd\BP_"#/B)PFdx"*Kx 9<@FF~ ̜{SEe8.#=eHGb⃨SKl@Np "c \:i=l Idc9ҀL#/a5AӆyXqhҠzń(#mf6|PII )/w'LRPb9B4fXv\ p]$"e'6q5TT%-=Q0E#=ѨUF6JLP@("[0!MD}6SҙW{pC#=51)$abi~ϳc)4r]ʣ-d(#=PaՅo*\LAÜčn {i@!~tmHވ(3#/M3Gv* h^|dd OFuACIAE#$JJL1!$tM#4"EE쀘Z#/ I~78HEtAzuHGA v ؐHW$.|dLJ,P44PD4$#*J`hR$#= ) uPSSUU#4$ HD@$PRL$DDR A5@E1-I3KI0LU$QL4BİBDD1IPDĄQMRP#4L4ADA C24AHDP$S"R T0TM#4D0DA1L@C(RHR#=J2LDP*C#/D%$D #/T a"8HXT!)FePCH<`F#/B"@(J]Dx͇7=3r"|]\hL=~ yur3`эg Nˬ(k#/Hߧ0dIϕ?<v#V7%ʉ8щ5HQbhfha6Zb*v24-UT)UEEUj#=Bj>E^&X AV0?JPfJTQދ_({$I{ ` };;X~*UF#/"fe;bX%&|R5.2G#=g볍D ,;td^'wS>9#4܎s:*Hp13%I)$/ #4)A\ y2D@e+a2E<ƚx(ػטygM84&BPR-,/d*Z(d-%hsb";Q)SYkuaK)ɆTkDm|;6Q1sB\7@c] cDpl0w#=I@GWv Y-1VؓBgGzFK#yPJfؘd R@4Bpa#4C܁ZNTqSҚFݾo{,Cd:!I03d TaMxHuPry{ CN8d\&ubJ4}+:aEf t` ԼԮ9URt$$sDiqMJJOA5QCCp9d`TgPѡ۱;lV#4], :u$#4պ5MqwSNղ,8toQzdnPi~"#=hg( w2L,<(*r1Djx&a~OWMa#=c"PH Ctܭ%wyb#=dZ",#/Xb5ЍGx̓ rN<{}x{X=(y}{Cv2_dcd@j ?bSs-(DChvMHؐd7BIuf`Y!](]wJ*mkeKWNbdB%zW7&9X;Hk@۫yNGVSSUcNJ8=lv`13;j Fg|>>~r؞ڛ>ǜwT@f#91 F4 ANA>1C"޾򫲡FHʼn+C=W{ez䷪Cv^(eh! !1Lu<9|=K096#2ߥóZN|t]tE ZcImsq&߈&&Ѣa$h*Fclhc#4nKO3݂IFPceO-5hhJ{PDNq!r10dɐ=M(U"948"H (VIJJD4m!KP+'~'l.}ݺׂy?o$x> OEL§F#/p>;EPhAW+cwd9&)BŃ0ҩM?kAه7ń8(K@@ 'Ξ|]d夶M#4Z-/DUXmjO?VG0ECS,'Dseh-hHuΖȋ5GDdimQAs(䇜#4mL-.AL_n}[IY%KO+#=PPE#4TKDHT@h#=` d%)`iL(JJD Dc@PA/`äy!#=s(R;2}8#/";+}]hC1(|g,aW#4ѥ 45dle؇Jm$UQP)B9EHgnE\Cp˵?p@DPMUFp74L?oO%N!ʡy8sn)yȧDNj(a1TMsjjH#=J&f*`V#=h*%uzٹ?Bp9!h@#/`;5TӵWj<#/f#44Hj= #-#2Q#4aD"#4` Dz0X57}Bgs_!5bQ⽾%t* doغsKQ/:jHPɇ؇3 l~z|4}g!gfpX]{ j7@p*]ѻ[v1PnKBt%'FI>l=6vPdI#4#/Ł!_9{aLECLü ya򧴀SMifH~\H+H T#4  CQrTV @f@# >3QrPJ@"PTv`S@hրZmIo/D.A\CoSOprrRz|E8M! DToNE1bQPyn1W#+c^BWb+aww!|8pO'sj]$H!!GPy""4ĕ~8xz$F,Ž~l>5B5ZjN5DXS?4hMuIP@upAHwL,t|b DwLO0Z#/}AՁ#4ȃ3Azz~Kouz=7~sA3(}#/R=x)FG֤aXC;~X8[{')d%Q%q زBt =ȟ'EGy5i55V#x+4&0R(Ӑ,tE<^>B_-s}1nV#=f<`+'=Ip,4,b#40Wp#AĀg!G_?d':\MQ5(59cg[#/1lsoBnaO 9=F51#J0]ZX0GHcY<,bGqS4E;pK 6pDV]^i ZL:G|m!(i+8chk0vN G}F4zK$"rGr֢#{%y#%pPF{;Ɗ#=Ye.z8MD^7Wۼŷ̥s݊bhNm6rO%+`(i#=";&zuRWsӆ'"!b(T=ɡ#=lˇσ4plm5N97 dFUK<;̿)|:O5avkݙM{]vH<~c㫺f("[@2 rWaUrA!Im_ x:˔I*"mD D 0Q2#/D(=qeK&޽#/qzʃ@E_ !,`'!ͳ>4?,Qk~?/eI Gg`\P e qC$9'C`C;KR&1IpzƖozq;yI)/=>li5z)NA5u7B@)~:`P*$V!J!BdaD40+@-(#=U߀% i]`SLcBWTִ0$KB4^B#/bR`p}NlXR?5Ad3#/J\HGl u.KD)B4#mlkNp-:J R-MJfu{<#4TXB;N?+#/V衁9ϼP #=%U~~Tt ;'Ui #/U#= CPvkχn~<un{F{,rJ!5z%ؚQ&Y-Hbb %B=ro9ğ5[MN:4S2'D:6~7=]h<\©u@{L26>76$[P9<@E8*j& R}ZblI@$BAshhh$'9{F2b"* `-*fN׉6 RcpRԀ _!yktkB|J#/mfk#4x'@$O#C /h_<8,mJW &a0[o 3/YRgPcWr'TmL>4aQ~v#4w2\ '-ɇqN#=|G(`t2[AarNu3:##4#=#4#p˷;#=fn;9$x_41A(!Ec,f =(&s؂4kW#;hx+Izn<3\*\L▕栧WPG3v#4.xwsnv)X[>RqS.k<uIg᜜Lw(y!"N)U!D+FHowltv*iAN@U! RP|iʋ'b`aUT~yrv4: (8ȊD A3!^ޱp]1lÐij YyHOt30Ya^b~ueyyG?qLo~^PۻG#4jgB?=ni0:>3!= pd88b8:-N*4E%dz6,LA 5ء!"YlR$D'3Т)Ð13ȡ¦tv9`bڄƂ^C(@"OVonL%ttaD}r#/ iUфA;a!*9sICCjjn #4˚z uals,̞H/~y]L J%#4(&|}r< 3: _H/R @RDMHSM-PLQ)RP@R!44#/ATE4#UDKKSM#4 DLDHU K #44S2R4+BRUP!@SIKE4-%2TADTPRJM$|DQM T RBB@IT@UU DT2$A$P4RD$-EB%CJ!(B,"%E$LQ-SP Q0#4E13AT2RI4 RUC#=DQAD5R$*@HP@? ӕM1+.Dc?<;sߔkp#/y(=ЊR_, S#/Ah@1*Bv8Pv~; uWL)HPxyJ&!H>?VD{{}#=kI$EiMR)0AizQ-DħL "#=#=h!imĥ!4AECJU/#JQ"/q85)T2ELMA%{6E+IHIyp ߋ&~v/&hfOvyCAcagŲ"R#G #fpsN0Ljt#=,LsH>#=HB#=r'x/YΆ;#4"/`^߽hFFe)( "#=)"#=)JQ#=#/"M GP 9+9:C' R~I-G4珵kCa:C v9;Ԛg5OĜזoj̛3 L]8iTxYG #=N6 8;"K$- tC,7ٔuv$hUd8R 1&>֊Թ%caJ0Ău֒Cs8&jR#=HD6#/ɰJ#/=-`H5EP_/1ʘ$yiIȎd % pGP@=^i1>9@,U>y|=fJ}r)b1pT#=s>(#/[1i _c-M|<ȃi,1p*z:4~3~D)GL`m4eA(ybp9<hvDEL--e\0H2dG%0<򞟠?a53j10H1PJf柧\Xq%mPTAk8UQE!BUVaic4YĠTq"zCOC)AE5(B& 4JHBE(DAT2A!BLSUTHTJDOu"}cMܲli#E4TG\`Q(-AV$dˌlf#=cURw:g&_›j*j%$_}K2CmzM/gGŒh-wf%յ!Jzƃf<!eR#oaqeDr{.XoZ#MK{Z˭SC%#=pܳI$#4Q`hZu4q!4:urp'#)(ox]LK~%Pqh,1T[( M ]8,L8C#=Tq@YuNO^=Z&<| ihiIOڛySrji ?>yb !}*ŝ׌oB]Д(A7RD.r= ny?>9f#4l~ȥ'!9'uDgE{!t9R9v#=FǪnzz|#B(ѪMR2-R& 1/|!ɤ9#/P,fy̟LX'ĎrnLA3Mp15t0tɢq10CSN!$}ىJ"0 ]`g [X,a6ɂɧq vsuo+SW"h;'qpxqE8#=r6+S6'>#/;\D#47HcMG=k Nc%4!*\'\);ܠY5qbnWn]XGōqFbUA#=# hT.5#ۉq-45dEv*ű$jԏ|gGۤ;O峝?}m8b/fGq{1FcJ.W{e(2n 1Ct\Rhly|諡j[\4Ŏ*&8Ц3g^l%2 T#4 c<[6|pp;C4ˤŪ$A!4A'4i35@+`!1%Q< *fnF6~LWiy&uASUj~H/q#=#/w V x]0z. K!Ƞ%0 $b]""$qA1/_:A!N L~,p;JII #&({CDZ"$xiM=TJS8UNHi|>69pzס{Sĕ]Auy>T(J"$J, ñݞ=; ÔѣDzj.Ζ+sp7BZ `#=F  tȚ"z}Хr>J}WHvJY{,OiwAAIOv=k:SI>(g < H6Jn:A,7 Z#4#/R!;. {滜#/ P4]K *[%TEH$#/>L8-%%DH)JT`!h#/"Q"Vj$&@#/faX4s{J*UL?É 4P@xBZ%M#=iJ?w<3Ӧ~-E߽#R b$Ֆҍ \XM!VF#P!XTR%F _6N^BѶ6ڎg&+6a =+F#4t9`keZNpZ!ps3L8`Ď;4pvq+do h1U7.fLccYbM-%ミ0䨝30xp߇s1l{m9\cKQ͐Dc$)@ĿI.r]Pn1v#=ǒ5+h"]s!ذ%3%#/kk|]`vz.(F+#=GIuv9v;\B)`G9#=֪4%9!L 3A#=x2> WY=3gso$D?%a;#=w<0=ϱ3S_bTL.-}EPO#4͎k E6,+ _ǿ-6}#4ˇH;Q,NM1C|IԁIY؀;h@]xBއPCn=ʺPog#/l"~8hG{Cip2COӌg`uHTAA3ٷ1"83 q>~+o8?PX~gfuӒso-C%hld^ w* DSwVط#=0KqUi[Sbu_Dxi㙉t NpPh0`;'H׹!} */`*`OQqo-)ǐ $0zj,8_yf IO9g#4eɸ!>^Uaebz8 |0z_|\]ʨ؁GEt䉝1)L:6O%#=:Nl!jB9%G_Džx?ƚ8#/" <~}ƣuR`;ℒĩ|GCPz2衊0LKCsSj%lᓁ3$#dMЫ') fAb(J00-,ll 2` 9OTȦq'VE 想K#lmuyTV"X'6" 2"#>zZNӿhw}eZL7jj~\T8d1 򯕄#4IܡTy:wl:WϝRppK0?`lqTܔm>)=X@#=#= 0#/9.'| {9'L(_ȦhJI\ASh&pP`>Ivy( 6Ӑxꟊ8!u0O! 1뱈O#4jlԭc@7g?<-40W,@U7#4^CZ)<cEj$Nupa"p\aCU&St`̈8'U?J"&BƛbO{oJpq o\J>nz&WɃڞK&~ϟz7#/$D ;U : @#=vނu8k%j|z;qad%wټI!E'0s1D#=Srۓ3Ί };G+Hk3*3gdNAl;_dt2EPoikxL{Vyw#4D)aWPbUUh_ Nv8~( 2bw` AҔ iO+2Z"#4X z@E'Qޘ?O-h2͂La5$\QAͩQ d#=W5JI*r G{?#=+ @bގq_#4$>B3@#yrQRy%&#=4 JDAz᝟UT̺۩d‘SU#/6,w?oƿ1~L)#fH:X)\#4Y=R`4$^\yjrQTD MN0tg]X$аeX>347ĻV-Mjz#/٬P!Ō!ӂk#/]ssLATOu0`sYȱ6@8r/|rpBhCbl |tGRz#=uNfh ǯP;*X1h^A &0#=p3Ǐ{ًZY0~긓*wv9w?en.z6La=#4##ZǀpTan?EIMi&@O'af!/]H>N g$z~HP)HQ;+>h &:x`t)¢i\\#4vx;n;znwln#/u :HsKL>h+Ьhy7¡5:eEH~~8h@pHY+T[L'ǧ~kNRW{(C#/ ~d=} dDĠ~i J]Ί#4<7t"quj- @4(P:#4(ʓN#6"#4nKHi)3W)]4"M AJ(P Z@Ҡͦ#= ZV iV0 TP1'4B[\7#4NJthJcM/5E"e-+`#4w>HuXܳǔ4P[9Ah#/MPmzgAF@ ) h6!ȟ(s`םAbW]ͳ!Y$݁(Ԝh)#4A#!風늏M4$B%(Dp)AE8NudBj}FnRYPQx4BI!fBJ#=#4@+'"cfx#47#4kHZDEj!P|Cg?O}53ėKq_#F9mݰ3O!׼v4. 쓞(~ Lɡh9ßkԥ 9qRhM(Xn~ŷ_ 3ɆSLD·Jwbgc˚6DntO0;2 S#=dU^r#/笢iNZ|^#=~Xk_~zЀ>Yߗp/),"} ۻ@=ۜB^h`S9clbט:{ SN+yw#=hi]ߵ20msc:KDmޘXwKF`IX1e$T4ڠe((ilm#=)W=nʢ.?qg:A-0˃Ud! K3A(F(hSDlFy.R0l-%iM0x{)X"H1LK:0dt9!GԦIp)jR2ZKf bG3IH +ͬT}f=#45%Ũ˲G#4?4(Gs#w(N܇^#40mQoVaN=)F<%VZRZ{H>:s8ƙ@驈N١d($ǰo$PLAV0ĭ!$ʨƚ@9Y d ^J#=qc6zM 0IטThPUw;eHA0mn%G"0^sc=d;Sv7*4v"`Wj#pqŁ.TZ3nHP_#=4qm7JU#=D=xMD(DY啙5}j`_f#4FtEI䆣NŔlBW9!zSOhI{;DA!yDŽ#=Wk.c$00:2dec"66Q(jbN,H8,Hކ$uz@&dp9NJj@#48{0p<f,X;B#4dK+1PfW@ 1eh&` V *`""RZ&()R,<:$Sz):CM45Hs2 #4ƬK`"qD69k,6g㎘c[JQӘyp]Tp+ 1' TMYqsF'TijsuT,SvGv[!q*HY "|"q͢ h*ۛ']}%+tpj8\9!Q`9ktmCr&]ߺaGl|XdhǶ܏>2jgG~h<di8[8le΋*Q:KWLw*b5Á,q#4+rlU!Fzⶌ#=D#Oc4:]ULV7sÀ`Üa +u8yxIT3T#=d#/EB#3z_iG3@%#4pO9;*hSD3wA"'"8~mHOgCf)]>(f8ȸ~SV_<=Q{jFcm_-WLgLXTְmPm=8(l [4zy]?IDtaBvT[º4**m#{\a쾡4!wMA[b5%9zUߗdBog e8 8 BB1 BAp0D2&&E?A,GOά{n9QAjZҧJv*BzN;em_FŤ#4i ˄Ѣ" hYOiQP4j~lP@ŵË)f{^tQ~r(etgM+713gKhcKza#/i֮r~xEրzx8yMsþҽ +ʃ#=K4*΢vZHR%ޱ\o#4Gޓ2a%QonAoz̷fǫr&` ]\)\G5o>q9!Im#4ej*szN` U]96͌XFǓ{Q`k#=E*WwtiVvj*,bW# bcoqm9Co ¬o~z@Ɣ"Xw49$w`y@'R|#ʀ* )*vW>xhj4MF66#=K c 9ޗKb(#/bX3N'NlRCn=T-QtT#4 BJ(4}7ЪޠVHyM@#/1ɣ+SLN<6QFJxhHvZDlSS$I#46-$,qᱹ͹8CCˌ h0#/2S9!@qV-[*9<$s#/Pt:F)#Fh1*Ib&0O,*Z:HU LKIC3KlB0$NJ%JBhC#/`|\R (M*#=XnO5nT8i@Y#"#D RZ#Fc#/R&vŸYe :}Ÿp&#=EZDhafCD$8~tJ=#=!RCH&mc񈦁$)bTb.?lhWӴ_,\:NuOP`3L]HAR_ #/냁"@A3ONt#_*- J IA%1#/CMQ)DĀDуPqewLJ4iQ!#=#49 #Ryj B:T7q\v=/#Kw{[|f4msh[\t#dRtC{4fT02`~XHA$#=&Or%5ñ'˜9@1Op Ayk*I^J`J`-hmV:+Sh2(:Ctf:0|BՓl%"V ϹUDE#4L&Zr/1\5&hh2ixRɆ.-#=E9EIOMu@Ol(zzZٍm:FH۾Wkۭtc8zԆhcr6٣cXr#4pHiظ5{A#4c27 HRdfr#4JF"uZ+U4jYH&TQGzP244=9#=4^VbJ&#%گ rm2]{zh7rD+?<'#=HT}z9 (+p3#4il*ŅshQ9IC:BtQLEC "hB$#/)&@6O*;)U?W"Phh$EQ#4-4zù#4i>m@6Xbx'cَQҩ}qO }M#4+V,QDkqAŒ0Re0d/9KBatݚPdN+4DIlMY4m[va1hm286Lf [I*` y dIQ#/%A FiQ(JGgxZIAEiM&ձtsr%۰pns%& A1!4)L2s';$5ځ#=r78#/R !!{2:ͮ{KE!X#J҃Ҡ;sƪ4 :J&(a*GC w4D }R*%Ѕ#=iӧ#=2s#/A/$CApWߌQv~6`#=a+#/(AEGCɟq~ހ?h8W#/xc!9DX44ҥ&Yd7Oz8Bjq#=4[v1K8na=}+AP;HPXJ(fj ZwSED70]\-u}ߤ1(1MZ|n,olB*3U#/%3YOx()Y7O)lH(4TdRՁգVj>Gl#4'$:]#4IdO*uV dR@՚)mӱX#/ߙgz:Dtҧ%) |Ȼ jP")7zPD-Sc_w QTQK͍Gat"@d0$il#4[7kl 垞U@@4#@4UpyX0Miܰ( #=:8oTdt v#4vɭZQ QJYZE;ȼBwuT:nmֻ0P6-1v^Ra# w]X"!%Ou6[c#/Iyc_#4t`'Ln{B4#4#DQa!j4INT.6VIT1YRX4é?Dǁr#4U &g~ .Bk#4dXhXxwb$UdI+!eH껪_s{|_ݜ6}ksq?ΆH`7,YV':%;N)LYJ:6%Qi1*<QC @ N{~ei@"#^`*д21{t.%B쯬80#4pw IODF!#=AiQJQ:Ud$(*i $H("FF(% f hYQQ9f ,y꯯bfs  ~]gpa~f[jsNP*b)LJDl(xՁ#/ 0ҊL#=DE0n#/pTԗM;y_&^z{A)Ti聨ޭA(ߎ2B!:# yü.`2vX(rzFf!`~Dh*!"#4cG@Ԧ@<.{;tj$#/ִPd ti,BE#ЩetzCfc#=#/Љ@>$z]Λ1ɓ.zJ)C ZD"( P]>(UM YYhQTZ2qL" I@ e8zT"q4eh;0P}YY4@|Ԙ uf˟#=DY{.T!#=f9TL̇,NTRcY44?򶟝ۘVZ-eKbO0JN1IO?/<ʔq=$ @dNhL)$i6!n,t;=/R*EQ!Oˊ)L#2T,#/o!ABWFID>4UO @JD '@rC !&^&Tyb+EM$wk>:eIUM"Jp:CRFZ*I.#/F*#F0H(ѪXj JHdzZTܜ$ĚCGƸ6DҜ(~ϓXP!0 M4!Mmއ0%&QW:iY}XkI6{ Ȕ|s%)Rީm95YYƸ¨ȤD&6ڢ,:xVh=#=d0 Ad(T}EP=E }y.P`?dB ƻ\%lj#4t!jnY,n4h@P뗉Ȓh1pChr1!@5@l4&8IPw:CLY&Q1 P5 .ς#ٙSNiZbEa#44>к"}i0@sƊ8xebmSє@@z|Ƌ=1"5Jw/ό,Q0,qO~11rI3#4ms` ^sC=XFғ2)2.6ǦɖtXJ߫6X83SZSV@%A4ʊhUW[ƮTIa}#/9Yͩp)Ke8"XpᓗӉ=Ý&dlL Ҏ50h_-tEQ7|ͬ`v{7hnNF9rQ- j#4mZciiDR'j^G Y /3Pp#e7EcLoy3z2E#%?XC7v\J#4`h`'ѻ{8|:#/aQQT;#==54,3ƕG>YHDڮg%qG~RNݑ,7=J0#Ϧ_c>/#4ƨ;4P?!3"#4V$ϳ`Ã+iyȌiݣ<(Қy+o9_c2z۔[J|^3kzf7Y~I/)4R3E[NzِW#49ɠVR9)(-3BUaÏ;/z *dH37)(N{c*I#=ABH"$D+AV7g]efkGv|QXI}1a I;F#4m#xJ`IXwZ/"f3'of6\5`.Y5*կ[1e֭ڡYS'Y#/Tcr?-a\@#ѐ]RHL$i P=B,}J{:c#QӅ~XA5R2ABRC `R"NXVz[e]7=<[O\^uONaA&3rM@.JpwxF38'˖B4k>#4WzCOl}@G ;R67KOw}Jx|C5@PQ3$&ll( $Acԝ<g/aAqmz"49)pRSz~&pJ#40 E"`hSH4"*e)jO_+ϻɦGğjB@GC%||gk}!?^(ux:Oz')JHy"BH20!T~H4!'kdBPۏZ4j 5@#%{?)C? ] ;O)PC`;|=}L倕Pq%[(0Te`#15SfX[ݑ`TbM?(ƧyAȜMLB HeHdA{#42>@i< /s-Z__(ŗ4Z`1M>j#/2sp?g881Es|M|hPX8rH Be*uDpw,%d#/&qTDn+j#/W=K+f.&Dٜls|U2RN#4h4r Ќ Kw :laBO)ld2cE1 lN-XQv9^u`Gr;5ЩdƄ󴌗}Oh 丞R)rBua@!AF K)#VOJ؀DnJ@dAT\>7rAזIVwՐÑHstXXPQ({zUR<_wmBH!(4`;V-4cb- m2d%BLqjfuA>?&&#=w}>ҰÝPFߍ* YƸֿ =̬tRuCfE|`6Hrc4#/u4 +0qSٷݥp!"g W\rO$ZDv #/`s&J!#?!أta@pє3|d,;Br_-]7pi5D]%0Si4t 4nI͐)U%aI%%!B`<#4PzFU-O4$8s]A}_1y0хrIR}lvރCR%kA`}3a'&?\'laݩT:ѦU>`U;=Yi Lń{dL4kL1qHc-ezZF`q0 fF#4{p8t1yj#4]$.fFMvX)T@#=2J2ӝăɪ1[bt,ю+ M,#)R2јAAC@oUbMAk ! m GFE8XD&ȵAAa7eLFCW(4DAFC!6>ff˓uT:`pg [p`A;ӎ; #=HVI$#=O4ƭLX<(xз dbkytpPt~QnBPR0(pbB7cV.l BAw[:smX։y4ٌhl+y/#=Ƽ I4#/Qn@bU>#ٜǐyr{ALF4v]9jSU #=TBB9BZGICEϳ9!8E E8q5T<0㸍fΪC?O|^SMr#/S&REUB;ci'͏ɪ@=F}Ni%H 9#=Fj95ˊMQAOv`((*HQ#4HIQA`*f(`>$5QߖA1#4vܺsC»:=II$ a'@Ќκk;5bn!#/VicIr'+Gλcj*/#4ͺE1 積hveH#<70c7ahІ'7FAMgmh/MGIJCAЦzz:py]4%0ZS'$h")'U"|<\3T\VL6?8rrWO:b'e6B =ρNJiTX( bƱs)!372Em%)#VX9y<8+Ucg gE/--X,%wC(V#=j:URL#4/ :xOmInٽ#31d(ȚԘ#4"iJ>,cf]75#4;1Q٢^f,';x5mgMć`o)UiEbnr1!&.#=7cm ܽ9hWMGN\=!/12zkILJf+<\"똰#!Ʈ#4-;BWe3qϞبpcI #=GxH2#e#&k`QHQɁXh@\GtR3 'DXdj#4bcb[@dEdU#=L64$`F͏3zFM1P&j<~ 6Pk0#4q0kHJVo[!hzN.B|-KT'|ʖ˃'[({it3'y9#8c d1 {'YC)=[$MjcfO]\>?>Jp. .NLȫTGX2#/:I"lh65BT1NpLhD(SFR>[Ȇ5r=D=LywʋSCH2  FDD"8xd=`8N*8zB u[ 55Vt 26"e=;ApSjM@tT~OTXCA[TE.n%7pbƢ颶m+{z{#/bQRJZH #=#/(Z@`eX#= "dd"#/{:R4B@UHAG$?F)O,4;:)"Q0/5~ok2whz?n@CXB#=Z hh6Ƃ` B|RLT¥L$Jn#d@]]+ 'MM_ʲ{ (p¾_Z#`DRi&D"TJT#=$f@$#=8֐ճN[h?ez3b[\L> .pSnFe* j/2j$`2#=(-]iG.t` neFA=@ h(k XDK3TunCFhM@=~{?߯ U\ATQ'#/HvWGcY0'wVh31##/qb!oqןCEL7hgѢPd='L^IL;|:']#=RO0Zb(yW|}64 FEYNBP! q3}7#/ʜ:#T$؂1TqU!8Bq4W!dSHum5W2h+T(4,G_jwZD:ok0@u.kkr5}H7t=]˒!o)'ʥ#4z8%*o'`{wmHP-HX}4%ͪ!L}~:#/쮐i.B1)@M4A|Cs#H:{W.mQ A6E."rivҺ#/:@p8/#s*%9RikI1)CBbґ#=iXF3 whM|{L!B(g!.yG/QIrO{0A#4-#/J!:|OHh`=!̗59'H1) A@, !Tu8##/)%Ӄ:dE1M<}Vf}9G,D^6@U墴$SIM!4^5q#/ޢ™JJ`8/f~ou"D%銶vUf6h}oq) XPH%0̼5,VԿ[ #/P.hs$'ݹ#4'pV#4@NאG="V!nP"R&A#/#=H rQM#=ҠR&Z$`h"tGdu N;#=I4R$z#=I4H{DF)IiDZB!HQPbV&#/hhFQFQx"lQznZT(y}_b[?0|ϭe7g~}v0? ,~XoT8|=D2 #/x/o68pQ #=Д, Mm/eTH#423w>}}F֓#/` %6]rq0e "hHbHJHJ"#=P &"#/ @hZ#/J ij HB" F#=^O71n89mjRÍ#4r8Fy#NG%MUP:$ ݳ''wh#=9vLM cErqIjNMYH8QֈB8R9F_>g^rW鹌ry袙-^'I #=faI@ir"q6k ByB(2RH'#4l-hJy1,LۅᗐoBZ)8?FLfvIp8I& K䆱+LSc $lö֊vtpp$>xSڣARԐEADmpVw6 6wcEm9$"J8sus&5ΎhL= P5L\,E1LQ3DCBRR!S$F)cxK;!TK%ߩ%: }|s2Y2n?9eYR 3!yv޷"=?A5iw&*1}Q",tpkI̚y!!&êxj:WNLg&P=#2~9ZSӔ:8I2m=pY]:Ր"i3aDHKSШUw{f*rL?FDmm.M8y5.#r$uE5cn˜E5-dQqEid޾7QO#={#4VJy2J_U?ұ ]q1rPAwUXԃu[Q5B_vLfZR=N n>]mbRz&;MG=y2BǂV_LqɌvQEˇH5)W:l(#=XB{I(N1V;:8nz9JOw3?=~祮saB{Tʫ?̳Y)8s)q1\#=F}7-8 0=iו$cYeWF" ggwn,̦-N) "Eݽ/❎(;rZ~۸SYzds򙲯F>[)v*{QqnI#=AwF!5־-GU 1_qciw:YC)[ s14e!R*75S{;UGZ#&s#>z0 },$Ҋ#/9_vj_kgHzqm"N.-xQ2Nb9g&6)}3.p%wD] r&ݛ΄BVm&ڠn\ۘæ܀Y4ebf=j]6.T.C2TbԨx 1{ՉT88;JXxfnHkSscpקS%ҁ&T:xCWs8Qs <7KKCW}aT#{D1o0;s߇ !AC#0{zMw4vE˽-t=h})VQJ]cRDmwo'mR6?ZMzH_䱦{:*2\bŎ14bI[!#8~R;5Nq2srMs\I<$7YW1(H}#{14,kUKl2w]6dˁ7]M)}%ju9L+.Jx3ӻ׻ԋIW*$/! s&PhBNbbTNw#=Zp]38S#ʭyq1)ӹ$:Bhh#}øeBb}1A"l~2udu-I5s5~޸}"P/i[{7MC[x̨K!xgV0a ˤ4)vTLmda6ӯ 6%x~ޣVvQ|'iҧJQiB#qOL1J#4c?h'mJpxMAgD$xH$q2|.5:sa3Y<&^#=M&l=5F7][(OCx\&{&;8i·&T=û>N+^ix3a)S QC&%?/=YVtx ҕ5VrvєY<㷬3*%Tdʋ-DŽ?pՄ{_V(#=LPef6!B.}-Lu`~&JxP52q<-=]&U+1T?zRW(}L<pD_$^FY5#fdjY]e4RQ=xiQsWtKFwdkWoOpW4H|8S#=+Bn㊊qIb26[]]Rn^;+8xekM"D@)G};2&b1,q:n(%oL{lɻ#Dq֎dZDnolm8UJiΙuqf?zW^S7o3}asVq>Vlߒ;M]moee#iSr'JcNptw;ZCIӶ}_oKep<%AM㍞xǯQAALޙ#cS;& afPi.f#4\q:mZrЂGHGAvr^KvUG3k/BlvUJ:n5aqljr/ <&`;b{HOiu˲MXoc2$O类T򍾷#br#$AfbI/;UmpCsp.{Q={ADyRX֖;%"OIFA5yĞ5,vÃ[bi- 3l~:QTvvfͷ͖Q&ٌ*kh4GYr :nY7˳e7>ҚP!B5#4H%̘uVJ%ODLo=;Sf(>Ǯ&;D$΅Nvîm'9gc{axUW'sR9^#L~L:_:u7Zn,PA"3Fu㥼,nBFp`.-6HˡJ1ZWx6s~So8, e,×(t,ן{t!s?b91lsCK%ץTgϯێyJcem ۄ,U5Wލa3dZ^n@-(6av4؏e1I'I:k݄oWʘ|ruD0S0RNY` ^^r%ED|Vn'Yr}&ʂ7'hϋuM#=)bTVU>#=‚A1:<_k%[PߥFsө-);yvd?C3wT"kڹ9 BdV|irXZ$K/eJ#4Wg6b:U>S?#4)͐8vdh8#Pui*9*p_-賀uy,cmRz=]UuְGR>g!IsgE{#/ 8aHP%UTQՎZJ" 0߮pWƼXYV+$$PI^N)9yBwmRF^fD\{D䩡B4R#JtM(l"#4A*Nxc"\^ q8G! A`dw_.&d-dd4:_|ۧ/`wCűcKNgFޓd#=5Q6TT#4 Dt4PQ-**R#=P*%#/rtvI|aܞsC\ icT7l=ն0.ƒyArjX=G!b#1ә"%J;%\5Q!NP}5Q1c#*O)lIvM8tQMDӻM?"#4 ̣#41DO@y~fEAKW2q$CsBa')]R"pt((p9!A$(D cn#/w`H `:3LѢ'cnB~]`6ykA9}gr7,ƍ͹F!h6J_ܼz+#/ۆxpi>X#4%pEQ#=.ޤYdF؛fUJ r= чc@"MI[QF=s[NAIX_i)Hh'{cGa=Ww-Wϊ< yc=ts`tz _:_%ԥUQIVt(]P@T&&{[o@QJBE !%SP]9q7#=6۲.%0[a"i#=j.H&uD\LѦ,ES #4B)|:E'?g?]#=&f?0gKKzJDESE!LSPEAQD $@B"3(ЀЕUU$SDT! 5*I,- T$T"$2#A!AM50QMQ1A-$4RIUM%ERJQKEE4HULE@C4CԂ;2<Q_?F!/?B>H? 7h9>d9I2mN&s*{1owֶ$C RNػ#4P < *q'&I8Gkw2 P?;>>MDAc=u*ԚP4Ӧu@a|1 ,1 Q Š)cw=5oYl@zğ}8x0Jb^Q3Y$(\_\`EmPjf񟆩C|!˥0Y2L5z}g =BS&A;켃`b"(4>|.5#=1t!y>7"?[)OL>Ag*H=60(^ϸPPL)0E $Hģl,dڈ)%#/"ԘؕLT&5Б*PS#JT4LAM4P4ВE1!IAMZ)))0*iD?xa*4C14DT#t׾hڙ*b#=[#8 󂰰hf(}&Nj)-lu+4&7y;{ǥNM#KDRcM|"WLsv#4A{tOmnv#=E`ŴTG&XjyXOY i0ƾ!Us7/W(OޯbitO%#D0Vh~88E}#=% #=T(.lxŗiW>o‚3 r0,#46l`iK[Q+r,ߜ> g/19k=xa8 ^mJ<,;t#4B'b#4LH=OUG[Ƣ)\{.cDkDQPDǗ9E"!V4p_|ۯ短>5OG#=5K#4(_jGi~xyJsبo>*cz{beU"&C_IN:I?N{w#4Y>yE8 ?ߨbu#4;#4'KDFA{#=Wlbf#4^Ʉ:6q@P=#/y:϶+q#=P 9U%S *WxSWb\#=LCWy:^@۟HԔ+%Tp8s;Mx5t]d&?tc꟣@N9;U{& opu]TAuNMf:vGXŠ=ҠB019Kçӿ؞Vߖ}?Hz^&S'CBT )2dU6I't9,M~kkswɹ6lÏq.4+q#yk*EO tþvR;O=LkWc5{!lw FieYWY^%xivЯ,m+w_ɞ2#I/k|6 yыr΢V5ΦyU#4! VNMbA4p8Դqp#=`9}mITrC_9/amRiH8Т;szlܴF*ܷjcQN2ʸ$jP gP$ɌS~<>A,Cp&".L 1L;zEf-8~o:#29u0}MO99pL7G"'*k'`$DjYq̐bN=*C۲\ÔԅYjӔekI:RywOZDM;Pe#4@CsgTZU'4#2f Ԁ"Tr^jKh#/#4 Ӷ/T#=xf+BD\gQk0Nxm,{.ݠPZtLCi׬ylP>3uX~Sr LfK0Vs,69Ϝ``.ָ9̖^Tl։M@Qk)ᣘ#= i-PNWYH]d[`5Qkkp -Le"PgƸU="жkYv֟Bдyuo-,=I(łOS ꪝޱNR#4U1?52M" b/DACq)_'*#=u,1.暦ʙqh%h-e1ńۯf*4!3>YJUjcShke0E6 u02;duks-NLӘ M &/(bk*Ydf=r e͹<`=O4p&噞d$t #4vsC,'˚3( S!`q* u5x1MI'2|K2ܹvi09:MccNۆJJW,NvFzC/ e zՊ /t`K`ypzƤEU2$Pۓb2Tu00QTP{%n:#=FC  2A)/Ǽq< ;BFDTMvAG$95&)7^C$3ItGJCdqc]G#`h9ELWQǛ8#42fܙ{Х꼓,ヤ0)<紑й+aLa%pВ<Аp`Q#=ժWݓ&S9#=E1l%,RC?'Kwʒ7Ш7u5kZ|/,r@j"@d1>+ >ڝ|ͽx+ܪ+r@#/A\J:tV$SK68B#/#/#=æH8B3zd_SO\\0v6qP܇|!Qi %E)#4¢܋zZJ#/6Hsa)c&#/HS{y/LgDqײ#4SVhu8twʈ{>dtiؗ[3[Y?.'>W^2#/WNNHSI,/5rvs$h!a}(zjR0#xt$cnLSs(1UBF0]aa[m?e{1s׸Yc'B) @Q*PB- YdO>}~9@e#/:"zHIvt1 IB)1u9T5<< ~2xBP=ElNul#4R`Qˉ6p >_Ϩ\ݐa2]8#N0n4^pG6""1Z*v;P4sbls *@䮏<"5]QqZ#=-ग़1puLr&+9ΤQ( UDvv!TS mCc9Lm*F0ʙd!=WK@Jpx8˙8L*!}p |>rS!N|p֛cLٜBkxk q܃ʟXF|5s>%vF*ֲL/[wׄap1+36ZV`o3]hduFl4Wfі%& !<ᆁX KG}q_Or#=f1ӂ@> ~WSE"YWa>LM{Ϣu!9R+Ô4hh#=ђb86ѽ9q[pqj34r)(Xjd`~=akoSL -#/Un\36o2$SU64mcmG9$u&䮑9 #/qT#4{s&I']M;շN2ZhrR sgV<`|<`#=#=hP)d%#= {c0P&m#+Ƿ*۱Մ?5LɖQd!k}v©^-7:ꪜItϯ`陯)`<~C/ ob#h^"}'КuQN|/V4YTU.`ڼ]N3"#46fb ]o5Z\nΒrÖn'Ktd"#42;\lNhTiJlvu£aEQQ!MM/Pc6N.--,4UD Q90'9 9S]ۖ j @Je0Kk "aXF!23',HK( 16c`&!9ӱwF/v"6xnsu1bzICСɉ{08B]`RSU )M]łxs[Q3bIIӆ[:ն,] [sN M0QJhhhx' '!@;ۧ#=,,ezt;Ú(2V2S/hVBdE:rU.1䩠]6qHӁk2f'T[_ya,~GMa6rT27aԐ<=#Lr}f:xwBOG'SCm5NLNܼb鷪_9n>OK+_Je8yQoi)9ot\M8VOhTBUN:Pqii71ҝ\B(XN,weJ,C#=gIf"%LG9AmKA(|\V(Z*%s9 T%2˄!"8heYg\욢ò:eO-燣nb"tۉ7H6ݔǹyP%A4I(‘J̎#=a|,X'02dַΦp;b|wI#=1& 3 :4yR68:iTRT>.;:Mݯ8::C>e&x9I(o|>ΒβzBlA4023١$N,]b< .iTdàFPf,_|#/FA@AW=;x#4+2JK4/vP7ef&PZ%fM#=$<ȴ>ZfD(CxO%U6 5v0[ CLQ@AJ! |CM1%@D("D#=#/ t04Gw/0*EBLb#=J(8UuJA1&H)v #7"DL#4K `{@v]Wy 2D*D'7O=qghb7ET)MtL:?ٿ]}?w}8rBJ:#4`,@'xҞN~#/q;`̔ G#4C|3Ss8!?Z&#,31V&iֲЕHxCR@#=:-#/B)#=d)(JE(B$B`"%RM5UNW= |E#4-#="3l{Qh#=J("#=J*ZB!`$*iDJ=DD|@8#="#= b)Z!#=!dD~H$@UI#4$G:0RHrB!@Ne6/ ZCd{툪PrHBOœs+^QClMRTIG CTDPRKJ# R%0DL)I%Du9"#=5I~SXP`;]SUUcШQ/_}ϋc sB!zQ 785~Rr(mD#/gDH1anrUْW9i7t̠-#'%sӼPvwy6+Ȟ*C>8 `Ga,f!`F)+c < BFgZ=0ij^HJ@& w'=>@EDC h?-% QB A()@ Q#/Ӳ(5JAL0OF 8d%&6*Z̑J!#/ RC‘d#=Ih@r Y%El n4#/ĂvuDP^;%πQrJ0@I晭h=i$#Dag>+MNͶi J_>9@e#=IN\#/Ԯ1}$hWi*v>&.:u嵫b%>O>>dPB{KBWXq书KAZhl{dcTr!4.d/T)0b$2Lu0pD~(("$[:<i(Pi#=X#4U:r`:3NJHc[m궚{(k$F4IJDI)EA KIE%PR-!bU%)*2 @ȅ1kgH}"vMvC0 )T! #B"jK4ҏ2((Z*#/!QIHuzǶr'd'͑Ur2Os8>D:hQbi+&=XKF6#=S> mgHS5@?$2b&!5\@ёږ>`@|v^^p,Ny|XC#4O;iTΔ?& b1h )k_ფ@}G`-*t48*i`!r*$0\d`#4$L#4) )Nqg30#49B#4Q D#=6R#=6DH ($`1#"HF1'ԱP! .`a3 %M- 0L+vL #40,bLDC>Q>0vxl#/DY؎E"$%!;&6njL#/"O#/aT ML># ɤ:yQ5< XR0 VA'8na4%c{"xit" U3~ERL3D1u;Gy~CRJQA1$QHF?OԎCO(] {%ܿ̕hXN!! q#4^EU0^sa#/)m Q9aQgtGs^ml^ELV㩲<4 gIQg2RuYu߬ɃyMJЏ#/t@7OO59sHIHD#4=Hų_hGl1b*H䄑 KJfIdkpO-ݦH(d9(`\bq2^s]QbfS̽@|`>~?8nN&&JX/ǃua S۞SxeU1J$:ÓA.̈soA#=:3GQRS#4)Ć()d!N4}Q1\[ -{]ŸsEgV,x[|e'ךPv2P(XWI(Hj3ȎXYt)#=pMh%"}dPe6l&D˰ xw ߇-Qt)'43@ʑ>k\:G=q(u?a!~IrDE,(•0r,NA2TXа" Ilǰ輴ȢG+f9cF3膆Z$$SILh&#=?ќFpČ}"M$#=(@@QJLHt!#l! mU)i9fN/ɘACiA?ϑt&s I$WIFA$#4MS@MNaU,Jʄ(3w|J/`HS`Kd8۠ D$IA15$Ad䉪#=")JV(,R"M5ӠX kF3FaZ.# )ZΠNNj%2}9 'Aht} @}}rC/[*H( #4FH~( &@Gf]#=g DINeDDQ7p:ub#L#/`kkM,lp#45!զ@y N8ڞzi{#4GyQ%J:HvhxxNY~XP8Dڳ.ބ )a;㴻|@#4 #L<0)#/bM$XAS"! \OԮ ThJ}Yg囬2#mǂ~'qfiplLvL4| NEj֯X8#=c[1w6;agŲ< 9<,΅c9j:X#=2V6PwvDqyד#4-unL[O[2C!cdJFmYۿoTW@5$_N(պQNV&tс+#D")V,M?U*)t|9$酓mhj7L&֤[D&'GsM1 d+nma6ͦ&\l1퐔eԄFpf2iS7$:t)W)O._#47D\Өt8#ْk!!g\6XqQiǶ`8s~7XHF#Dlm#4،^>L(qɒ"QHS#=֪O#4I:i39C;LS#/)*`0yofwuI<,|=gKMOZXSJI|IݟCE[&QфAGNKbIC:~ݓRtm%G^1!l_.V1нcfٙHPwAGTjqGE#/ڥTDbj&BVX `u~MzE'w5ӈ '$Y7z=x1h#xG~YοPm4^l8{7v|l d`@B)0AO6@tww\@L4E1#4AUL)!@CT#/$USCQTL @B 2@ 4J!Ae *'yP5!d#/d?,Hu!с W죨,11P_+q x[&#/F Hɠk?kW!D,zR3Y#=6<\N7SS>h&T557EHSf#=1Ah ʹ|[Og~ǪaμC_3#4acz?+w6`k|'^!t2#4I0Ze&kAhm4܌Zp`LisT8v,9k]!㸎u5dcu牜m_a:#=;"3 vx;r+61SޛtL ̞i˓ ȸׄ]<z1#fM&]l̨dhjK2JW:lڝt94OHZJ8dx8'21 zX#4^% )F$f É$P;[G82P| یx:Yɡy|XC#={Y:F~dM]Jaa#/19RaHKe:N̛Z0$.JUhKjBo,ݱ"!hHNv|l#4*bF+mz60RE%S b8"cc#="l>]mF9μSi E 2MЩ%'$~4r@Э#׼k7nlxCX>_yQ$=5#4:܀v\@%{pi` (@M&C>ZqY89j0x '˲vBtHBkʂ#=jrfr#4?WU۔h$xD=` @ Bu=x#= P!JC (Pa9Nҕm+PILÚD3/E)%$W}d/Ϥ/SDu42DDQ#4!Q!CQ!_*4PDMl}n?t#4UzOq6!|Akmӏ_O^QgLs#=#4ּo=#5|3! L>NN1p:Ru8|FV9J;#/!-M-6t_):mKWF.7h8P^agTP 3hkʗ$DmGG⨊gU,#4L;qD 3BJ3% X5YB*9(:Y7#4C<9Uy_~ӫNqA܈zBAQM ĭʠ2:ݕ6O*@?HN?u(/!Q fBLL ,A;7ޗ_vCPO3CN#=EܑN$#^ +#<== diff --git a/wscript b/wscript new file mode 100644 index 00000000..d9411e2f --- /dev/null +++ b/wscript @@ -0,0 +1,260 @@ +#! /usr/bin/env python +# encoding: utf-8 +# a1batross, mittorn, 2018 + +from __future__ import print_function +from waflib import Logs, Context, Configure +import sys +import os + +VERSION = '0.99' +APPNAME = 'source-engine' +top = '.' + +FT2_CHECK='''extern "C" { +#include +#include FT_FREETYPE_H +} + +int main() { return FT_Init_FreeType( NULL ); } +''' + +FC_CHECK='''extern "C" { +#include +} + +int main() { return (int)FcInit(); } +''' + +Context.Context.line_just = 55 # should fit for everything on 80x26 + +projects=[ + 'tier0','tier1','tier2', + 'vstdlib','vpklib','filesystem' + ,'mathlib','tier3', + 'bitmap','scenefilecache','datacache', + 'launcher_main','vgui2/vgui_controls','vgui2/matsys_controls','vgui2/vgui_surfacelib', + 'serverbrowser','soundemittersystem','vgui2/src', + 'togl','vguimatsurface','vtf','materialsystem/shaderlib', + 'materialsystem','studiorender','materialsystem/stdshaders', + 'video','inputsystem','appframework', + 'launcher','engine/voice_codecs/minimp3','materialsystem/shaderapidx9', + 'gameui','dmxloader','datamodel','engine' +] + +projects += ['thirdparty/StubSteamAPI'] # ,'thirdparty/libjpeg','thirdparty/SDL2-src'] # thirdparty projects + +@Configure.conf +def check_pkg(conf, package, uselib_store, fragment, *k, **kw): + errormsg = '{0} not available! Install {0} development package. Also you may need to set PKG_CONFIG_PATH environment variable'.format(package) + confmsg = 'Checking for \'{0}\' sanity'.format(package) + errormsg2 = '{0} isn\'t installed correctly. Make sure you installed proper development package for target architecture'.format(package) + + try: + conf.check_cfg(package=package, args='--cflags --libs', uselib_store=uselib_store, *k, **kw ) + except conf.errors.ConfigurationError: + conf.fatal(errormsg) + + try: + conf.check_cxx(fragment=fragment, use=uselib_store, msg=confmsg, *k, **kw) + except conf.errors.ConfigurationError: + conf.fatal(errormsg2) + +@Configure.conf +def get_taskgen_count(self): + try: idx = self.tg_idx_count + except: idx = 0 # don't set tg_idx_count to not increase counter + return idx + +def define_platform(conf): + conf.define('SOURCE1',1) + if conf.env.DEST_OS == 'linux': + conf.define('_GLIBCXX_USE_CXX11_ABI',0) + conf.env.append_unique('DEFINES', [ + 'LINUX=1', + '_LINUX=1', + 'POSIX=1', + '_POSIX=1', + 'GNUC', + 'DX_TO_GL_ABSTRACTION', + 'GL_GLEXT_PROTOTYPES', + 'BINK_VIDEO', + 'USE_SDL', + 'NDEBUG', + 'NO_HOOK_MALLOC', + '_DLL_EXT=.so' + ]) + +def options(opt): + grp = opt.add_option_group('Common options') + + grp.add_option('-8', '--64bits', action = 'store_true', dest = 'ALLOW64', default = False, + help = 'allow targetting 64-bit engine(Linux/Windows/OSX x86 only) [default: %default]') + + grp.add_option('-W', '--win-style-install', action = 'store_true', dest = 'WIN_INSTALL', default = False, + help = 'install like Windows build, ignore prefix, useful for development [default: %default]') + + opt.load('compiler_optimizations subproject') + + opt.add_subproject(projects) + + opt.load('xcompile compiler_cxx compiler_c sdl2 clang_compilation_database strip_on_install waf_unit_test subproject') + if sys.platform == 'win32': + opt.load('msvc msdev msvs') + opt.load('reconfigure') + +def configure(conf): + conf.env.PREFIX = '' + + conf.load('fwgslib reconfigure') + + # Force XP compability, all build targets should add + # subsystem=bld.env.MSVC_SUBSYSTEM + # TODO: wrapper around bld.stlib, bld.shlib and so on? + conf.env.MSVC_SUBSYSTEM = 'WINDOWS,5.01' + conf.env.MSVC_TARGETS = ['x86'] # explicitly request x86 target for MSVC + if sys.platform == 'win32': + conf.load('msvc msvc_pdb msdev msvs') + conf.load('subproject xcompile compiler_c compiler_cxx gitversion clang_compilation_database strip_on_install waf_unit_test enforce_pic') + + conf.check_cfg(package='sdl2', uselib_store='SDL2', args=['--cflags', '--libs']) + conf.check_cfg(package='libjpeg', uselib_store='JPEG', args=['--cflags', '--libs']) + conf.check_cfg(package='libpng', uselib_store='PNG', args=['--cflags', '--libs']) + conf.check_cfg(package='zlib', uselib_store='ZLIB', args=['--cflags', '--libs']) + conf.check_cfg(package='openal', uselib_store='OPENAL', args=['--cflags', '--libs']) + conf.check_cfg(package='libcurl', uselib_store='CURL', args=['--cflags', '--libs']) + conf.check_cfg(package='bzip2', uselib_store='BZIP2', args=['--cflags', '--libs']) + conf.check_pkg('freetype2', 'FT2', FT2_CHECK) + conf.check_pkg('fontconfig', 'FC', FC_CHECK) + +# enforce_pic = True # modern defaults + + # modify options dictionary early +# if conf.env.DEST_OS == 'android': + +# if conf.env.STATIC_LINKING: +# enforce_pic = False # PIC may break full static builds + +# conf.check_pic(enforce_pic) + + # We restrict 64-bit builds ONLY for Win/Linux/OSX running on Intel architecture + # Because compatibility with original GoldSrc + if conf.env.DEST_OS in ['win32', 'linux', 'darwin'] and conf.env.DEST_CPU == 'x86_64': + conf.env.BIT32_MANDATORY = not conf.options.ALLOW64 + if conf.env.BIT32_MANDATORY: + Logs.info('WARNING: will build engine for 32-bit target') + else: + conf.env.BIT32_MANDATORY = False + + conf.load('force_32bit') + + compiler_optional_flags = [ +# '-Wall', '-Wextra', '-Wpedantic', + '-fdiagnostics-color=always', +# '-Werror=return-type', +# '-Werror=parentheses', +# '-Werror=vla', +# '-Werror=tautological-compare', +# '-Werror=duplicated-cond', +# '-Werror=duplicated-branches', # BEWARE: buggy +# '-Werror=bool-compare', +# '-Werror=bool-operation', + '-Wcast-align', +# '-Werror=cast-align=strict', # =strict is for GCC >=8 +# '-Werror=packed', +# '-Werror=packed-not-aligned', + '-Wuninitialized', # older GCC versions have -Wmaybe-uninitialized enabled by this switch, which is not accurate + # so just warn, not error + '-Winit-self', +# '-Werror=implicit-fallthrough=2', # clang incompatible without "=2" +# '-Wdouble-promotion', # disable warning flood + '-Wstrict-aliasing' + ] + + c_compiler_optional_flags = [ +# '-Werror=incompatible-pointer-types', +# '-Werror=implicit-function-declaration', +# '-Werror=int-conversion', +# '-Werror=implicit-int', +# '-Werror=strict-prototypes', +# '-Werror=old-style-declaration', +# '-Werror=old-style-definition', +# '-Werror=declaration-after-statement', + '-fnonconst-initializers', # owcc + ] + + cflags, linkflags = conf.get_optimization_flags() + cflags += ['-march=pentium4','-mtune=core2','-mfpmath=387'] + linkflags += ['-march=pentium4','-mtune=core2','-mfpmath=387'] + # And here C++ flags starts to be treated separately + cxxflags = list(cflags) + ['-std=c++11','-fpermissive'] + + if conf.env.COMPILER_CC == 'gcc': + wrapfunctions = ['fopen','freopen','open','creat','access','__xstat','stat','lstat','fopen64','open64', + 'opendir','__lxstat','chmod','chown','lchown','symlink','link','__lxstat64','mknod', + 'utimes','unlink','rename','utime','__xstat64','mount','mkfifo','mkdir','rmdir','scandir','realpath'] + + for func in wrapfunctions: + linkflags += ['-Wl,--wrap='+func] + + conf.define('COMPILER_GCC', 1) + + if conf.env.COMPILER_CC != 'msvc': + conf.check_cc(cflags=cflags, linkflags=linkflags, msg='Checking for required C flags') + conf.check_cxx(cxxflags=cxxflags, linkflags=linkflags, msg='Checking for required C++ flags') + + linkflags += ['-pthread'] + conf.env.append_unique('CFLAGS', cflags) + conf.env.append_unique('CXXFLAGS', cxxflags) + conf.env.append_unique('LINKFLAGS', linkflags) + + cxxflags += conf.filter_cxxflags(compiler_optional_flags, cflags) + cflags += conf.filter_cflags(compiler_optional_flags + c_compiler_optional_flags, cflags) + + conf.env.append_unique('CFLAGS', cflags) + conf.env.append_unique('CXXFLAGS', cxxflags) + conf.env.append_unique('LINKFLAGS', linkflags) + + if conf.env.DEST_OS != 'win32': + conf.check_cc(lib='dl', mandatory=False) + + if not conf.env.LIB_M: # HACK: already added in xcompile! + conf.check_cc(lib='m') + else: + # Common Win32 libraries + # Don't check them more than once, to save time + # Usually, they are always available + # but we need them in uselib + a = map(lambda x: { + # 'features': 'c', + # 'message': '...' + x, + 'lib': x, + # 'uselib_store': x.upper(), + # 'global_define': False, + }, [ + 'user32', + 'shell32', + 'gdi32', + 'advapi32', + 'dbghelp', + 'psapi', + 'ws2_32' + ]) + + for i in a: + conf.check_cc(**i) + + # conf.multicheck(*a, run_all_tests = True, mandatory = True) + + # indicate if we are packaging for Linux/BSD + if not conf.options.WIN_INSTALL and conf.env.DEST_OS not in ['win32', 'darwin', 'android']: + conf.env.LIBDIR = conf.env.BINDIR = '${PREFIX}/lib/' + else: + conf.env.LIBDIR = conf.env.BINDIR = conf.env.PREFIX + + define_platform(conf) + + conf.add_subproject(projects) + +def build(bld): + bld.add_subproject(projects)